深入T-SQL高级编程

局部变量的定义

declare @变量名 数据类型

赋值方法

set @变量名=值 或 select @变量名=值

set和select比较

使用场景 set select
同时对多个变量赋值 不支持 支持
表达式返回多个值 错误 将返回的最后一个值赋值给变量
表达式未返回值时 变量被赋NULL值 变量保持原型

常用全局变量

print '服务器名称:'+@@servername
print 'SQLServer的版本:'+@@version
select @@SERVERNAME as '服务器名称'
select @@VERSION as 'SQLServer的版本'
--获取最后一条SQL语句的执行错误号(547:外键约束相关)
print @@error  --值大于0表示最近一个SQL语句执行失败的错误号

数据类型转换

CONVERT(数据类型,表达式,样式)  --第三个参数可以省略,一般用于日期类型或浮点类型转字符类型
CAST(表达式 AS 数据类型)

datediff函数计算两个日期之差(查年龄)

--定义变量
declare @birthday datetime,@days int,@age int
--查询出生日期
select @birthday=Birthday from Students where StudentId=100003
--计算出生天数
set @days=DATEDIFF(dayofyear,@birthday,getdate())
--计算年龄
set @age=FLOOR(@days/365)
--输出信息
print '100003学员年龄:'+convert(varchar(20),@age)

--直接查询
select FLOOR(DATEDIFF(dayofyear,Birthday,GETDATE())/365) 年龄
from Students where StudentId=100003

逻辑控制语句

IF-ELSE语句

--语法规范(ELSE是可选部分有多条语句才需要BEGIN-END语句块)
IF(条件)
    BEGIN
        语句
        语句
        ......
    END
ELSE
    BEGIN
        语句
        语句
        ......
    END

WHILE语句

--将所有C#成绩不及格的学员加分到60分
declare @CSharp int,@StuId int
while(1=1)
    begin
        select top 1 @CSharp=CSharp,@StuId=StudentId from ScoreList where CSharp<60
        if(@CSharp<60)
            update ScoreList set CSharp=CSharp+1 where StudentId=@StuId
        if((select COUNT(*) from ScoreList where CSharp<60)=0)
            break
    end

CASE-END语句

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