




已阅读5页,还剩24页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Transact-SQL数据库编程,流程控制语句功能性语句,流程控制语句,1.语句块(BEGINEND)语法如下:BEGINEND说明:在t-sql中用beginend来把多个t-sql语句连成一个语句块,它的作用相当于和java中的大括号。只要是流程控制语句中执行两条或者多条t-sql语句的任何地方,都可以使用beginend,举例语句块,beginend常用于if语句和while语句中。如果if和while语句只有一条t-sql语句的话可以不使用beginend,但是为了养成良好的习惯,建议只有一条t-sql也要写上beginendbeginend语句可以嵌套使用。注:每个t-sql语句后面没有逗号或是分号。,beginupdate课程表set学分=4where课程号=00010001update课程表set学分=3where课程号=00020002select课程号,学分from课程表end,流程控制语句,2.判断语句(IFELSE)语法如下:IFELSE说明:else子句是可选的,最简单的if语句没有else子句部分ifelse可以进行嵌套。,举例判断语句,例:计算学号为0202003的学生的平均成绩,如果成绩=60分,则显示及格,否则显示不及格。declarecj_avgintselectcj_avg=avg(成绩)from选课where学生号=0202003print平均成绩:printcj_avgifcj_avg=60-if后的条件可以不加括号。print平均成绩及格elseprint平均成绩不及格go,流程控制语句,3.检测语句(IFEXISTS)用于检测数据是否存在,而不考虑与之匹配的行数。只要找到第一个匹配的行,服务器就会停止执行SELECT语句。语法如下:IFNOTEXISTS(SELECT查询语句)ELSE,举例检测语句,例:检查学号为0202003的同学是否有课程号C001的成绩。ifexists(select*from选课where学生号=0202003and课程号=C001)print有这门课的成绩elseprint没有这门课的成绩go,流程控制语句,4.多分支判断语句(CASEWHEN)CASEWHEN结构可避免多重IFELSE语句嵌套使用。有两种格式,其中第二种格式较常用。格式语法如下:CASEWHENTHENWHENTHENELSEEND,举例多分支判断语句,例:对学生成绩进行评定。,举例多分支判断语句,对应的T-SQL语句:select学生号,成绩,总评=casewhen(成绩=90)then优秀when(成绩=80)and(成绩=70)and(成绩=60)and(成绩=90then优秀when成绩between80and89then良好when成绩between70and79then中等when成绩between60and69then及格else不及格endfrom选课orderby学生号go,流程控制语句,5.循环语句(WHILE)有些时候需要重复执行某些t-sql语句,利用while语句可以很好的达到我们的目的。语法如下:WHILEBEGINBREAKCONTINUE命令行或程序块END,Break与continue有什么区别?,While语句举例,例如:我要在屏幕上打印10次“你好”。begindeclareiintseti=0while(i10)-在此判断i的值是否小于10beginprint你好-如果i小于10就打印一次”你好”seti=i+1-打印一次就让循环控制变量加一-直到i的值等于10时,结束循环endend,While语句举例,例:使用循环语句,计算1+2+100的和。declareiint,sumintselecti=1,sum=0while(i=100)-括号也可以去掉beginselectsum=sum+iselecti=i+1endprint1+2+.+100=printsum,流程控制语句,6.跳转语句(GOTO)可以改变程序执行的流程,使程序跳到标有标识符的指定程序行,再继续往下执行;标识符可以是数字与字符的组合,但必须以“:”结尾。语法如下:标识符:GOTO标识符一般尽量避免使用goto语句,流程控制语句,7.返回语句(RETURN)返回语句可使程序从批处理、存储过程、触发器中无条件退出,不再执行RETURN之后的任何语句。语句格式:RETURN(整数值)-在括号内可指定一个返回值。若return语句后没有指定返回值,系统会根据程序执行的结果返回一个内定值,返回值为0表示程序执行成功。-return语句返回值及含义见P218。,流程控制语句,8延期执行语句(WAITFOR)WAITFOR语句用来暂停程序执行,直到所设定的等待时间已过或所设定的时刻已到,才继续往下执行。其数据类型必须为DATETIME的,延迟时间和时刻均采用“HH:MM:SS”格式。在WAITFOR语句中不能指定日期,并且时间长度不能超过24小时。,流程控制语句,语句格式:WAITFORDELAY|TIMEsql_statement语句说明:WAITFORDELAY时间延迟一段时间WAITFORTIME时间等待到一个时刻例:等待6小时10分20秒才执行语句块。例:等到晚上11点才执行“学生成绩管理”数据库的备份工作。,功能性语句,1.注释符在T-SQL中,注释可以包含在批处理、存储过程、触发器中。有两种类型的注释符:-:用于单行注释。/*/:可以在程序中标识多行文字为注释语句,功能性语句,2.输出语句(PRINT)通常是在用户屏幕上显示,显示的字符串最长可达8000个字符,超出的任何字符均被截断。语句格式:PRINT文本|局部变量|全局变量|字符串表达式尽管PRINT语句只可以显示字符串,但在T-SQL中提供了很多的函数可以把其它的数据类型转化为字符串。print当前时间:+convert(varchar(30),Getdate()Convert函数可以将其他类型数据转化为字符串。,事务的概念事务是用户定义的一个数据库操作序列。这些操作要么都执行,要么都不执行,是一个不可分割的逻辑工作单元。通常,一个程序中包含多个事务。,事务,例:一个银行汇款业务:帐户A向账户B汇款(假设为N元)。这个业务将包含如下两个操作。第一个:账户A-N第二个:账户A+N如果在第一个动作完成之后,第二个动作还没有完成时,突然停电了,那么这个支付活动是不成功的。这时正确的状态应该能够撤销第一个动作,并且希望系统自动完成这个撤销操作。这就是数据库中引入事务的原因。,事务的应用,事务必须具备4个特性:原子性:指事务必须执行一个完整的操作,要么全做,要么全不做。一致性:指当事务的执行结果必须是数据库从一个一致性状态变到另一个一致性状态。隔离性:指并发执行的各事务之间不能互相干扰。持久性:一个事务一旦提交,它对数据库的改变就是永久性的。,事务的特性,事务编程,一个事务可能包括一条T-SQL语句,也可能包含多条T-SQL语句。事务可分为三类:自动提交事务:是默认的事务管理模式,每一条单独的T-SQL语句都自动地构成一个事务,例如,对数据的增、删、改语句。显式事务:每个事务均以bigintransaction语句显式开始,以commit或rollback语句显式结束。隐式事务:在前一个事务完成时新事务隐式开始,但每个事务仍以commit或rollback语句显式完成。,例:请说明下列事务操作的功能,use学生成绩管理gobegintranupdate课程表set学分=学分+1deletefrom成绩表where成绩60committrango注意:事务必须有明确的结束语句(commit或rollback两个语句中的一个)来结束。,例:用事务完成如下操作,向学生表中添加一条学生记录,然后将这个学生的选课情况插入到选课表中。,begintraninsertinto学生values(2009101,李林,男,计算机,20)insertinto选课values(2009101,C004,null)commitgo若将commit改为rollback,考虑会有什么样的结果,锁(Lock)是防止其他事务访问指定资源的手段,是多个用户能够同时操纵同一个数据库中的数据而不发生数据不一致现象的重要保障。当对一个数据源加锁后,此数据源就有了一定的访问限制,我们就称对此数据源进行了锁定。锁是由数据库系统自动提供的,一般情况下,用户不需要定制。,锁的基本概念,死锁是在多用户或多进程状况下,为使用同一资源而产生的无法解决的争
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026届吉林省农安县九年级化学第一学期期中考试模拟试题含解析
- 护理业务学习讲课指南
- 股骨颈骨折患者术前护理
- 胃癌肠内营养患者护理
- 社团工作汇报总结
- 事故安全隐患培训课件
- 放疗科护理病区汇报
- 船务经理年终工作总结
- 肺结节的术前术后护理
- 《老人与海》教学课件
- 租赁车位安装充电桩协议
- JT-T 722-2023 公路桥梁钢结构防腐涂装技术条件
- 法院书记员考试试题
- 车库顶板施工电梯基础回顶专项方案附计算书
- 医学装备质量管理分析报告
- 国际机场飞机维修机库施工组织设计
- 液压泵站使用说明书
- E190飞机舱门开关
- GB/T 3871.9-2006农业拖拉机试验规程第9部分:牵引功率试验
- GB/T 3836.4-2021爆炸性环境第4部分:由本质安全型“i”保护的设备
- GB 17840-1999防弹玻璃
评论
0/150
提交评论