declare @test_Var int \声明变量用declare,声明局部变量用@符号,变量的数据类型为整型int。
(声明)
set @test_Var=1000 \为此变量赋值,赋值为1000。
select @test_Var \用select 语句进行显示此变量的值。
变量的声明以及赋值显示
局部变量:就是用户自定义的变量,作用范围仅在程序内部,在程序执行过程中暂存的变量的值,也可以存储从表或视图中查询出来的结果。局部变量在命名过程中必须以@开头
全局变量:
声明变量:声明变量用Declare,可以声明一个变量,也可以声明多个变量,声明多个变量的时候中间应该用逗号隔开。declare @test_Var int,@test_Var2 char(60)
变量的赋值
Set :单一一个变量赋值
select:同时为多个变量赋值 select @test_Var=2000,@test_Var2='高级数据库管理'
输出(变量的显示)
Print: 单独显示其中一个变量
Select: 同时显示多个变量
全局变量
全局变量、注释、常用的运算符
全局变量是SQL server系统内部所使用的变量,与局部变量不同的是,局部变量只对当前程序起作用,它的作用范围不限于某个程序,
而是任何程序均可调用,由SQLserver所维护的,也无需声明它,通常情况下此变量存储一些SQLserver的配置设定值和效能统计数据,可以用全局变量来测试系统的设定值或T-SQL命令执行后的状态。
全局变量利用两个@@作为前缀。!!!全局变量不是自定义的是由SQLserver服务器来定义的,只能使用预先声明的全局变量,只能引用它用@@开头。
!!!局部变量的名称不能与全局变量相同。
注释
多行注释/* */ 单行注释--
运算符
算术运算 + - * / 比较运算符 > < >= <= = !=(不等于) <>(不等于) !> !<
逻辑运算符:
&(按位与) 两边都返回true,才能为true。
| (按位或) 两边只有一个为true,才能为true。
~ (按位取反) true变换为false,false变换为true,0变1 1变0 。
^ (按位异或) 两边值,一个为true,一个为false才能返回为true。
程序块(代码块)
Begin \程序开始
declare @test_Var1 int,@test_String varchar(60) \declare声明变量
select @test_Var1=2000,@test_String='这是一个程序块' \select为变量赋值
if @test_Var1=2000 \条件
print @test_String \输出
End
Begin
declare @testVar1 int,@test_String1 varchar(30),@test_String2 varchar(30) \declare声明变量
select @testVar1=110,@test_String1='录取',@test_String2='未录取' \select 为相应变量赋值
if @testVar1>100 \条件
print @test_String1 \输出
else
print @test_String2 \输出
End
Begin
declare @testVar1 int,@test_String1 varchar(30),@test_String2 varchar(30),@test_String3 varchar(30),@test_String4 varchar(30) \声明
select @testVar1=100,@test_String1='优秀',@test_String2='良好',@test_String3='及格',@test_String4='不及格' \赋值
if @testVar1>90 and @testVar1<=100 \条件
print @test_String1 \输出
else if @testVar1>=80 and @testVar1<90 \条件
print @test_String2
else if @testVar1>=60 and @testVar1<80
print @test_String3
else
print @test_String4
End
Case语句
Begin
declare @testVar1 int,@test_String varchar(30) \声明变量
set @testVar1=100 \变量赋值
set @test_String= \变量赋值,=等号后面没有写真正的值,后面的值由case语句来完成(Case判断给她赋值)。
case
when @testVar1>=90 and @testVar1<=100 then '优秀' \条件
when @testVar1>=80 and @testVar1<90 then '良好' \条件
when @testVar1>=60 and @testVar1<80 then '及格' \条件
else '不及格' \条件
end
select '学员成绩为:'+@test_String \输出的格式为‘学生成绩’+(优秀 and 良好 and 及格)
end
While循环
declare @test_Var int,@sum int \声明变量
select @test_Var=0,@sum=0 \为变量赋值,初始值为0
while @test_Var<=200 \循环条件,@test_Var<=200
begin
set @sum=@sum+@test_Var \每次循环时候的
set @test_Var=@test_Var+1
end
select'200以内所有整数之和为',@sum
break和continue
break
declare @test_Var int,@sum int \声明变量
select @test_Var=0,@sum=0 \为变量赋值
while @test_Var<=200 \条件,循环值<=200
begin
set @sum=@sum+@test_Var \为@sum赋值,@test_Var=@test_Var+1
set @test_Var=@test_Var+1 \为@test_Var赋值,@test_Var等于@test_Var+1
if @test_Var=30 \如果@test_Var=30
break \直接跳出循环
end
select '200以内所有整数之和为:',@sum
continue
declare @test_Var int,@sum int \声明变量
select @test_Var=0,@sum=0 \为变量赋值
while @test_Var<200 \条件,循环值<200
begin
set @test_Var=@test_Var+1 \为@test_Var赋值,@test_Var=@test_Var+1
if @test_Var=100 \条件声明,如果@test_Var=100
continue \则跳出100这个循环,继续进行下一个循环
set @sum=@sum+@test_Var \为@sum进行赋值,@sum=@sum+@test_Var
end \符合所循环条件的时候,结束循环。
select'运算结果为:',@sum \输出结果,运算结果格式为:运算结果,加上@sum的值
(因为@sum数据类型是整型,所以用逗号,连接而不是加号+)
Go to (用来改变程序执行的流程)
declare @test_Var int,@sum int \声明变量
select @test_Var=0,@sum=0 \为自变量赋值
test_Target: \标记,跳转至某个地方的标记
set @test_Var=@test_Var+1 \为
set @sum=@sum+@test_Var
while @test_Var<200 goto test_Target
select'所有的整数之和为:',@sum