- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第六讲 t sql程序设计
教学内容要求学完本章,掌握以下内容:T-SQL的变量程序流程控制IF...ELSEWHILECASE 学习目标及重点学习目标掌握在T-SQL程序设计中使用变量掌握流程控制语句的使用重点与难点如何在T-SQL程序设计中使用变量如何使用语句控制程序的执行顺序6.1 变量 变量是SQL Server用来在其语句间传递数据的方式之一,它由系统或用户定义并赋值。SQL Server中的变量分为局部变量和全局变量两种全局变量的名称以两个@@字符开始,由系统定义和维护;局部变量名称以一个@字符开始,由用户自己定义和赋值。6.1.1 全局变量SQL Server使用全局变量来记录SQL Server服务器的活动状态。全局变量是一组由SQL Server事先定义好的变量,这些变量不能由用户参与定义,是只读的。几个常用的全局变量的使用方法(1)@@ERROR该全局变量将返回最后执行的Transact-SQL语句的错误代码,数据类型为integer。在SQL Server执行一个Transact-SQL语句之后,如果语句成功执行,则@@ERROR将返回0;如果出现一个错误,则返回一条错误信息。@@ERROR变量将返回这条错误信息的代码,可以从sysmessages系统表中查看有关错误信息代码的含义例:使用@@ERROR变量在一个UPDATE语句中检测限制检查冲突(错误代码为#547)UPDATE StudInfo Set StudSex=ll Where StudNoIF @@ERROR=547 PRINT 出现限制检查冲突,请检查需要更新的数据限制(2)@@ROWCOUNT该变量将返回受上一条SQL语句影响的记录数,返回的数据类型为integer。任何不返回记录的语句都将这一变量设置为0。例:在UPDATE语句中使用@@ROWCOUNT变量来检测是否存在发生更改的记录。UPDATE StudInfo Set StudSex=ll Where StudNoIF @@ROWCOUNT=0 Print 警告:没有发生记录更新6.1.2 局部变量局部变量是指在Transact-SQL批处理和脚本中用来保存数据值的对象。通常用于下面三种情况:作为计数器,计算循环执行的次数或控制循环执行的次数;保存数据值以供控制流语句测试;保存由存储过程返回代码返回的数据值。(1)声明局部变量格式:DECLARE 变量名称 数据类型这个语句将会对变量执行下列操作:为变量指派名称,名称的第一个字符必须为@;为变量指派数据类型和长度,如果是数字局部变量,那么还需要指定精度和小数位数;将变量值设置为NULL如:声明一个数据类型为int的@temp_counter局部变量 DECLARE @temp_counter INT注:使用一个DECLARE语句声明多个局部变量时,在每个局部变量定义之间使用逗号分隔。 Declare @StudNo Varchar(15),@StudScore Numeric(5,1)(2)为局部变量赋值通常使用SET语句为局部变量赋值,格式为: SET 变量名称=变量值如:SET @temp_counter=0也可以使用SELECT语句为局部变量赋值 Select @temp_counter=0如:定义一个变量@MaxScore--声明局部变量DECLARE @MaxScore numeric(5,1)--将其赋值为学号最高分SELECT @MaxScore=MAX(StudScore) StudScoreInfo Where StudNo部变量和全局变量示例Declare @StudName varchar(20)Declare @Salary int,@Today datetimeSet @StudName=李明Set @Salary=50Select @Today=Getdate()Select @StudName,@SalaryPrint @TodaySelect @@Rowcount,@@Error6.2 程序流程控制Transact-SQL语言不但允许用户使用变量和函数,同时还提供了控制流语言的特殊关键字来控制Transact-SQL语句、语句块和存储过程的执行过程。6.2.1 BEGING..END语句块语法 BEGIN?{ ?sql_statement?| statement_block?} END参数 { sql_statement | statement_block } 是任何有效的 Transact-SQL 语句或以语句块定义的语句分组。 通常用于下列情况:WHILE循环需要包含多条语句CASE函数的元素需要包含多条语句IF或ELSE子句中需要包含多条语句
原创力文档


文档评论(0)