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

下载本文档

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

文档简介

流程控制语句,变量,SQLServer的变量分为两种:用户自己定义的局部变量开头的标识符表示局部变量系统定义和维护的全局变量开头的标识符表示全局变量,局部变量,局部变量的作用范围:定义局部变量的批处理、存储过程、触发器或语句块。1.局部变量的定义DECLARE局部变量名数据类型,n注意:变量不能是text、ntext或image数据类型。,例:定义变量sname为nvarchar(10)类型,定义变量snum为int类型,例:定义变量snum为int类型:,DECLAREsnumint,DECLAREsnamenvarchar(10),snumint,不能有空格,(1)用SET语句给局部变量赋值SET局部变量名=变量值(2)在查询语句SELECT中给局部变量赋值SELECT局部变量名=变量值,n,2.局部变量的赋值,局部变量在赋值之前,默认为NULL。如果在程序中引用它,必须要先为其赋值。,P136,3.局部变量的输出,PRINT局部变量注:变量的输出仅用于DBA调试时使用。,T-SQL也提供了用于编写过程性代码的语法结构,可用于进行顺序、分支、循环等程序设计。,BEGINEND,语句块的界定,相当于C语言中的“”BEGINsql_statement|statement_blockEND,P145,IFELSE,IFBoolean_expressionsql_statement|statement_blockELSEsql_statement|statement_blockDECLARExint,yintSETx=1SETy=4IFxyPRINTxyELSEPRINTx80PRINT成绩不错ELSEPRINT需要继续努力,3-105的平均成绩80,如果布尔表达式中含有SELECT语句,必须用圆括号将SELECT语句括起来,练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolIFEXISTS(SELECT*FROMStudentWHERESname=陆君ANDClass=95033)PRINT陆君在95033班ELSEPRINT陆君不在95033班,陆君在95033班,练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolGOIF陆君in(SELECTSnameFROMStudentWHEREClass=95033)PRINT陆君在95033班ELSEPRINT陆君不在95033班,练习:判断“陆君”是否在95033班,如果在输出”陆君在95033班”否则输出“陆君不在95033班”USESchoolIF95033=(SELECTClassFROMStudentWHERESname=陆君)PRINT陆君在95033班ELSEPRINT陆君不在95033班,多条件分支选择CASE,(1)简单表达式CASEinput_expressionWHENTHEN.nELSEEND,2)选择表达式CASEWHENTHEN.nELSEEND,CASE具有以下两种格式:(1)简单表达式,将某个表达式与一组简单表达式进行比较以确定结果。(2)选择表达式,计算一组布尔表达式以确定结果。,例:用CASE语句,根据教师的职称来分级,USESchoolSELECTTname,depart,CASEProfWHEN教授THEN高级职称WHEN副教授THEN高级职称WHEN讲师THEN中级职称WHEN助教THEN初级职称ELSE无职称ENDFROMTeacher,只做临时显示,并不对表进行修改,例:利用CASE语句对学生的成绩进行评价,USESchoolSELECTSno,Cno,CASEWHENDegree=90THENAWHENDegree=80THENBWHENDegree=70THENCWHENDegree=60THENDELSEEENDASRankFROMScoreORDERBYSno,循环语句WHILE,WHILEBoolean_expressionsql_statement|statement_blockBREAK-跳出本层循环sql_statement|statement_blockCONTINUE-跳出本次循环sql_statement|statement_block,-布尔表达式,进行条件判断,练习:计算从1加到100并输出结果。DECLAREsum100int,iintSETsum100=0SETi=0WHILEi=100BEGINSETsum100=sum100+iSETi=i+1ENDPRINTsum100,下列语句实现的什么功能WHILE(SELECTAVG(Degree)FROMScoreWHERECno=3-105)=100BREAKENDSELECT*FROMScoreWHERECno=3-105,-计算3-105课的平均成绩,-将3-105课的成绩提高5分,/*如果3-105课的最高成绩大于100分则跳出循环*/,跳转语句GOTO,GOTO语句将程序无条件地转到相应的标签的语句。DECLAREsum100int,iintSELECTsum100=0,i=0My_Loop:SETsum100=sum100+iSETi=i+1IFi=100GOTOMy_LoopPRINTsum100,标签要符合命名规则,并且有“:”,不利于程序阅读,不符合结构化程序的三种思想,因此不提倡用GOTO语句,延时语句WAITFOR,WAITFOR语句可以将它之后的语句在一个指定的时间间隔之后执行,或在未来的某一指定时间执行。WAITFORDELAY延时时间|TIME到达时间WAITFORDELAY0:00:05PRINT时间到!WAITFORTIME20:00:00PRINT下课喽!,-五秒钟后显示“时间到!”,必须是datetime数据类型,但不能包含日期部分,必须是datetime数据类型,但不能包含日期部分,不超过24小时,函数,P1511.字符串函数2.日期和时间函数3.数学函数4.系统函数,批

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论