SQL流程控制语句_第1页
SQL流程控制语句_第2页
SQL流程控制语句_第3页
SQL流程控制语句_第4页
SQL流程控制语句_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

流程控制语句变量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

PRINT

'x>y'ELSE

PRINT

'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')

PRINT

'陆君在95033班'ELSE

PRINT

'陆君不在95033班'陆君在95033班练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolGOIF

'陆君‘

in(SELECTSname

FROMStudent

WHEREClass='95033')

PRINT

'陆君在95033班'ELSE

PRINT

'陆君不在95033班'练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolIF

‘95033'=(SELECTClass

FROMStudent

WHERESname=‘陆君')

PRINT

'陆君在95033班'ELSE

PRINT

'陆君不在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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论