![SQL流程控制语句_第1页](http://file4.renrendoc.com/view9/M03/2F/16/wKhkGWcmCIGAJ0QcAAOIC0F0xXY664.jpg)
![SQL流程控制语句_第2页](http://file4.renrendoc.com/view9/M03/2F/16/wKhkGWcmCIGAJ0QcAAOIC0F0xXY6642.jpg)
![SQL流程控制语句_第3页](http://file4.renrendoc.com/view9/M03/2F/16/wKhkGWcmCIGAJ0QcAAOIC0F0xXY6643.jpg)
![SQL流程控制语句_第4页](http://file4.renrendoc.com/view9/M03/2F/16/wKhkGWcmCIGAJ0QcAAOIC0F0xXY6644.jpg)
![SQL流程控制语句_第5页](http://file4.renrendoc.com/view9/M03/2F/16/wKhkGWcmCIGAJ0QcAAOIC0F0xXY6645.jpg)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
流程控制语句变量SQLServer的变量分为两种:用户自己定义的局部变量
@开头的标识符表示局部变量系统定义和维护的全局变量
@@开头的标识符表示全局变量局部变量局部变量的作用范围:定义局部变量的批处理、存储过程、触发器或语句块。1.局部变量的定义DECLARE@局部变量名数据类型[,…n]注意:变量不能是text、ntext或image数据类型。例:定义变量@sname为nvarchar(10)类型,定义变量@snum为int类型例:定义变量@snum为int类型:DECLARE@snumintDECLARE@snamenvarchar(10),@snum
int不能有空格(1)用SET语句给局部变量赋值
SET@局部变量名=变量值(2)在查询语句SELECT中给局部变量赋值
SELECT{@局部变量名=变量值}[,…n]2.局部变量的赋值局部变量在赋值之前,默认为NULL。如果在程序中引用它,必须要先为其赋值。P1363.局部变量的输出PRINT@局部变量注:变量的输出仅用于DBA调试时使用。T-SQL也提供了用于编写过程性代码的语法结构,可用于进行顺序、分支、循环等程序设计。控制流语句说明BEGIN…END程序块语句IF…ELSE条件处理语句CASE分支语句WHILE循环语句GOTO无条件跳转语句RETURN无条件退出语句WAITFOR延迟语句BREAK跳出循环语句CONTINUE跳出本次循环语句BEGIN…END语句块的界定,相当于C语言中的“{}”BEGIN{sql_statement|statement_block}END注意:BEGIN
和END
语句必须成对使用P145IF…ELSEIFBoolean_expression{sql_statement|statement_block}[ELSE{sql_statement|statement_block}]DECLARE@xint,@yintSET@x=1SET@y=4IF@x>@y
'x>y'ELSE
'x<y'--布尔表达式,进行条件判断--定义变量--给变量赋值练习:学生的成绩表中,如果3-105课程平均成绩在80分以上则显示“考试成绩不错”否则显示“需要继续努力”。USESchoolIF(
SELECT
AVG(Degree)
FROMScore
WHERECno='3-105')>80
PRINT'成绩不错'ELSE
PRINT'需要继续努力'3-105的平均成绩>80如果布尔表达式中含有SELECT语句,必须用圆括号将SELECT
语句括起来练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolIF
EXISTS(SELECT*
FROMStudent
WHERESname='陆君'
ANDClass='95033')
'陆君在95033班'ELSE
'陆君不在95033班'陆君在95033班练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolGOIF
'陆君‘
in(SELECTSname
FROMStudent
WHEREClass='95033')
'陆君在95033班'ELSE
'陆君不在95033班'练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolIF
‘95033'=(SELECTClass
FROMStudent
WHERESname=‘陆君')
'陆君在95033班'ELSE
'陆君不在95033班'多条件分支选择CASE(1)简单表达式CASEinput_expression
WHEN…THEN…[...n][ELSE…]END2)选择表达式CASE
WHEN…THEN…[...n][ELSE…]ENDCASE具有以下两种格式:(1)简单表达式,将某个表达式与一组简单表达式进行比较以确定结果。(2)选择表达式,计算一组布尔表达式以确定结果。例:用CASE语句,根据教师的职称来分级
USESchoolSELECTTname,depart,CASEProf
WHEN
'教授'THEN
'高级职称'
WHEN
'副教授'THEN'高级职称'
WHEN
'讲师'THEN'中级职称'
WHEN
'助教'THEN
'初级职称'
ELSE
'无职称'ENDFROMTeacher只做临时显示,并不对表进行修改例:利用CASE语句对学生的成绩进行评价USESchoolSELECTSno,Cno,CASE
WHENDegree>=90THEN
'A'
WHENDegree>=80THEN
'B'
WHENDegree>=70THEN
'C'
WHENDegree>=60THEN
'D'
ELSE
'E'
ENDASRankFROMScoreORDERBYSno循环语句WHILEWHILEBoolean_expression{sql_statement|statement_block}[BREAK]--跳出本层循环
{sql_statement|statement_block}[CONTINUE]--跳出本次循环
{sql_statement|statement_block}--布尔表达式,进行条件判断练习:计算从1加到100并输出结果。DECLARE@sum100int,@iintSET@sum100=0SET@i=0WHILE@i<=100BEGIN
SET@sum100=@sum100+@i
SET@i=@i+1
ENDPRINT@sum100下列语句实现的什么功能WHILE(SELECT
AVG(Degree)
FROMScore
WHERECno=‘3-105’)<85BEGIN
UPDATEScore
SETDegree=Degree+5
WHERECno='3-105'
IF(
SELECT
MAX(Degree)
FROMScore
WHERECno='3-105')>=100BREAKENDSELECT*FROMScoreWHERECno=‘3-105’
--计算3-105课的平均成绩--将3-105课的成绩提高5分/*如果3-105课的最高成绩大于100分则跳出循环*/跳转语句GOTOGOTO语句将程序无条件地转到相应的标签的语句。DECLARE@sum100int,@iintSELECT@sum100=0,@i=0My_Loop:SET@sum100=@sum100+@iSET@i=@i+1IF@i<=100GOTOMy_LoopPRINT@sum100标签要符合命名规则,并且有“:”不利于程序阅读,不符合结构化程序的三种思想,因此不提倡用GOTO语句延时语句
WAITFOR
WAITFOR语句可以将它之后的语句在一个指定的时间间隔之后执行,或在未来的某一指定时间执行。WAITFOR{DELAY
‘延时时间’|TIME
‘到达时间’}
WAITFORDELAY
'0:00:05'PRINT
‘时间到!’WAITFORTIME
‘20:00:00'PRINT
‘下课喽!’--五秒钟后显示“时间到!”必须是datetime数据类型,但不能
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 科技驱动的数学游戏化教学模式研究
- 教育评估在财务管理中的应用
- 科技公司如何提高远程客服服务质量
- 残障人士的远程医疗与家庭环境结合的新模式研究
- 2025年隔油器项目可行性研究报告
- 2025年镗缸机项目可行性研究报告
- 2025年荧光广告颜料项目可行性研究报告
- 2025年碳素纤维磨毛机项目可行性研究报告
- 自然声音在小学生语言发展中的作用
- 2025年家具型材项目可行性研究报告
- 《中国心力衰竭诊断和治疗指南(2024)》解读完整版
- 《档案管理课件》课件
- 2025年中考物理终极押题猜想(新疆卷)(全解全析)
- 胫骨骨折的护理查房
- 抽水蓄能电站项目建设管理方案
- 电动工具培训课件
- 《智能网联汽车智能传感器测试与装调》电子教案
- 视频会议室改造方案
- GB/T 32399-2024信息技术云计算参考架构
- 2025年湖南省长沙市中考数学模拟试卷(附答案解析)
- 五级人工智能训练师(初级)职业技能等级认定考试题库(含答案)
评论
0/150
提交评论