【笔记】T-SQL程序

一、变量

  • 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:直接无条件退出

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,556评论 18 399
  • 《裕语言》速成开发手册3.0 官方用户交流:iApp开发交流(1) 239547050iApp开发交流(2) 10...
    叶染柒丶阅读 25,830评论 5 19
  • 初次使用androidstudio 的时候,需要用到一个滑动关闭页面的第三方开源library 于是需要导入第三方...
    Themores阅读 2,527评论 0 1
  • 虽然不愿意承认,在职场有时你的努力是苍白无力的,有时甚至根本看不到回报,你需要的是让自己变得更有价值,而不是委屈求...
    叶子随笔阅读 139评论 0 0
  • 婆婆走了,去了有公公的世界了。她极其不情愿,却也知道离那个人生必然结果越来越近。即使生前身体...
    田园小翠儿阅读 246评论 0 1