SQL Server基础操作(此随笔仅作为本人学习进度记录六 !--程序块和循环)
Posted lncc-zhangxiang
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server基础操作(此随笔仅作为本人学习进度记录六 !--程序块和循环)相关的知识,希望对你有一定的参考价值。
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
以上是关于SQL Server基础操作(此随笔仅作为本人学习进度记录六 !--程序块和循环)的主要内容,如果未能解决你的问题,请参考以下文章
SQL Server基础操作(此随笔仅作为本人学习进度记录五 !--数据类型)
SQL Server基础操作(此随笔仅作为本人学习进度记录九!--游标)
SQL Server基础操作(此随笔仅作为本人学习进度记录六 !--程序块和循环)
SQL Server基础操作(此随笔仅作为本人学习进度记录七 !--存储过程)