一、变量
DELARE @变量名 数据类型
赋值:
SET —— 赋给变量常量值
SELECT —— 从表中查询数据,然后再赋给变量使用SET与SELECT语句赋值的区别:
① SET不支持对多个变量赋值,SELECT可以
② 表达式返回多个值时SET出错,将返回的最后一个值
③ 表达式未返回值时SET赋NULL,SELECT保持原值不变注意:
批处理后局部变量会被注销,局部变量为@声明,全局变量为@@(为系统定义的变量)例子
DECLARE @UserName varchar(10),@ID varchar(10)
SET @UserName='李勇'
SELECT @ID=UserID FROM Student Where Sname=@UserName
Print @UserName
Print @ID
- SELECT和SET的区别
-- 【1】同时为多个变量赋值
DECLARE @name varchar(10),@province varchar(20)
-- 使用SET为两个变量通知赋值
SET @name='张三',@province='吉林' --- 出错
-- 使用SELECT为多个变量赋值
SELECT @name='张三',@province='吉林' --- 允许
-- 【2】表达式返回多个值
DECLARE @province varchar(20)
-- 前提:SELECT UserAddress FROM UserInfo --返回多个值
-- 使用SET赋值
SET @province = (SELECT UserAddress FROM UserInfo) -- 报错
-- 使用SELECT赋值
SELECT @province=UserAddres FROM UserInfo -- 允许 但是其内的值是结果集的最后一个数据
-- 【3】表达式无返回值的时候
DECLARE @name varchar(20)
SET @name='张三'
-- 前提:SELECT UserName FROM UserInfo WHERE UserId='yaya' -- 查询无结果
--SET赋值
SET @name=(SELECT UserName FROM UserInfo WHERE UserId='yaya' ) -- @name将为NULL值
-- SELECT赋值
SELECT @name=UserName FROM UserInfo WHERE UserId='yaya' -- @name保持原值不变
二、全局变量
- 举例
-- 【1】IDENTITY返回的是最近一条插入语句的标识值
-- 在没有插入数据前 @@IDENTITY的值为NULL
SELECT @@identity
-- 向类别表中插入一条数据
INSERT INTO CommoditySort (SortName) VALUES('家政服务')
SELECT @@identity -- 返回18 即'家政服务'的ID号
-- 【2】ERROR:处理因为约束产生的错误
-- 没有错误的情况
SELECT @@ERROR -- 返回值为0
-- 修改时违反检查约束
UPDATE UserInfo SET UserPwd='123' WHERE UserId='李勇'
-- 出错后,错误号
PRINT @@ERROR -- 返回547
三、数据类型转换
分类
隐式转换:类型相兼容自动转换
显式转换:使用CAST或CONVERT()函数举例
Print '错误号:'+@@ERROR -- 类型不兼容
-- 解决方案
-- 【1】使用CAST函数转换
PRINT '错误号:'+CAST(@@ERROR AS varchar(5))
-- 【2】使用CONVERT函数转换
PRINT '错误号:'+CONVERT(varchar(5),@@ERROR)
两个函数进行类型转换时的异同点
相同点:都能够把某数据类型转换为另一种数据类型
不同点:CONVERT有三个参数,第一个参数是转换的类型,第二个是转换的变量,第三个是转换的格式,在转换日期时比较方便举例
-- 使用两个函数分别对日期进行转换
-- 【1】使用CAST转换当前日期
SELECT CAST(GETDATE() AS varchar(10))
-- 【2】使用CONVERT转换当前日期,111为某一种格式
SELECT CONVERT(varchar(10),GETDATE(),111)
四、流程控制语句
流程控制语句:用来控制程序执行流程的语句。
常用的流程控制语句的分类:
顺序结构:BEGIN...END
- 语法:
BEGIN
语句块
END
- 举例:
-- 在BEGIN..END语句块中完成对两个变量的值进行交换
DECLARE @x int ,@y int,@t int --一次性声明三个int类型变量
SET @x=5
SET @y=10
BEGIN
@t=@x
@x=@y
@y=@t
END
-- 在本示例中,BEGIN..END..可以不写 完成效果相同
-- 但是如果在分支结构或循环结构中就必须要写
分支结构:IF..ELSE...
- 语法:
IF(条件)
BEGIN
语句块
END
ELSE
BEGIN
语句块
END
- 举例:
DECLARE @x int,@y int
SELECT @x=10,@y=15
IF(@x>@y)
BEGIN
SET @x=@y
PRINT '@x大'
END
ELSE
BEGIN
SET @y=@x
PRINT '@y大'
END
分支结构:CASE...END...
- 语法:
CASE
WHEN 条件1 THEN 结果1
WHEN 条件2 THEN 结果2
...
ELSE 其他结果
END
- 举例:
DECLARE @score int
SET @score=93
SELECT 成绩=CASE
WHEN @score>=90 THEN 'A'
WHEN @score>=80 AND @SCORE<=89 THEN 'B'
END
循环结构WHILE
- 语法:
WHILE(条件)
BEGIN
语句或语句块
END
- 程序调试
ALT+F5:启动调试
F9:切换断点
F10:逐过程
F11:逐语句
CONTINUE、BREAK、RETURN
WHILE:CONTINUE
IF:BREAK
RETURN:直接无条件退出