数据库系统概论(超详解!!!)第十节 过程化SQL

1.Transact-SQL概述

SQL(Structure Query Language的简称,即结构化查询语言) 是被国际标准化组织(ISO)采纳的标准数据库语言,目前所有关系数据库管理系统都以SQL作为核心,在JAVA、VC++、VB、Delphi等程序设计语言中也可使用SQL,它是一种真正跨平台、跨产品的语言。

2.Transact-SQL基础

1.标识符

标识符是指用户在Microsoft SQL Server 2005中定义的服务器、数据库、数据库对象(例如表、视图、列、索引、触发器、过程、约束及规则等)、变量和列等对象的名称。

标识符可以分为常规标识符和分隔标识符两类。

(1)常规标识符

符合标识符命名规则的,在Transact-SQL 语句中使用时不用将其分隔的标识符称为常规标识符。

标识符的命名规则:

① 标识符长度可以为1~128个字符。

② 标识符的首字符必须为Unicode 3.2标准所定义的字母、下划线(_)、at符号(@)、和数字符号(#)。

③ 后续字母可以为Unicode 3.2标准所定义的字符、0-9数字或下划线(_)、at符号(@)、数字符号(#)、美元符号($)。

④ 标识符内不能嵌入空格或其他特殊字符。 ⑤ 标识符不能与SQL Server中的保留关键字同名。

例如,下面SELECT语句中的表标识符StuInfo和列标识符SID均为常规标识符。

SELECT * FROM StuInfo WHERE SID ='05000004'

(2)分隔标识符

分隔标识符允许在标识符中使用SQL Server保留关键字或常规标识符中不允许使用的一些特殊字符,这时该标识符应包含在双引号(“”) 或者方括号 ([ ]) 内。

符合标识符命名规则的标识符可以分隔,也可以不分隔。

例如,下列语句由于所创建的表名My Table中包含空格,列名order与T-SQL保留字相同,因此均要用方括号来分隔。

SELECT *

FROM [My Table]

WHERE [order] = 10

说明: 分隔标识符的分隔符在默认情况下,只能使用方括号([ ])作为分隔符,当QUOTED_IDENTIFIER选项设置为ON时,才能使用引号("")作为分隔符。

2.变量

在SQL Server 中,变量由系统或用户定义并赋值,被用来在语句间传递数据的方式之一。  Transact-SQL可以两种变量,一种是局部变量,另一种是全局变量。它们的主要区别在于存储的数据作用范围不同。

(1)局部变量

局部变量是用户可以自定义的变量,它的作用范围仅限于定义该变量的程序中使用。

局部变量必须先定义后使用,变量名必须以“@”开头,且必须符合SQL Server标识符的命名规则。局部变量在程序中常用来存储从表中查询结果,或当作程序执行过程中暂存变量使用。

① 局部变量的声明

局部变量用DECLARE语句声明,其语法格式如下:

DECLARE  @variable_name  datatype [,…n]

参数说明:

@variable_name:是声明的变量名。

Datatype:变量的数据类型,可以是除text、ntext和image类型以外所有的系统数据类型或用户定义数据类型,如果没有特殊用途,建议尽量使用系统数据类型。

② 局部变量的赋值

在Transact-SQL语言中不能像在一般程序语言中一样直接使用“变量名=变量值”来给变量赋值,用户可在与定义变量的DECLARE语句同一批处理中用SET语句或SELECT语句为其赋值。

用SET语句给变量赋值:

格式: SET  @variable_name =expression

参数说明:

expression:给变量赋值的有效表达式,与局部变量@variable_name的数据类型相匹配。

用SELECT语句给变量赋值:

格式:

SELECT  @variable_name =expression  [,…n]

[FROM table_name

Where condition]

③局部变量的输出

局部变量可以使用Print语句或SELECT语句输出。Print语句一次只能输出一个变量的值,而SELECT语句一次可以输出多个变量的值。

用PRINT语句输出变量的语法格式如下: PRINT  @variable_name

用SELECT语句输出变量的语法格式如下: SELECT  @variable_name [,…n]

定义两个变量@var1和@course_name,使用常量直接为其赋值,并输出。
--声明局部变量
DECLARE  @var1 int, @course_name char(15)
--给局部变量赋值
SET @var1=100
SELECT @course_name = '数据库原理'
--输出局部变量
Print @var1
Print @course_name

定义两个变量@Max_Score和@Min_Score,将SC表中的最高分和最低分分别赋给这两个变量。
--声明局部变量
DECLARE  @Max_Score int, @Min_Score int
--为变量赋值
SELECT  @Max_Score =MAX(grade),
			  @Min_Score =MIN(grade)
       FROM  SC
SELECT  @Max_Score as 最高分,@Min_Score as 最低分

(2)全局变量

它是SQL Server内部事先定义好的变量,用户不能定义或赋值,对用户而言是只读的。

全局变量在任何程序中可随时调用。全局变量通常存储一些SQL Server的配置设定值和统计数据。使用全局变量来记录SQL Server 服务器的活动状态信息。用户可以在程序中调用全局变量来测试系统的设定值或者是Transact-SQL命令执行后的状态值。 全局变量的名字以“@@”开头。

SQL Server 提供的全局变量共33个,一部分是与当前的SQL Server连接或与当前的处理相关的全局变量,如@@rowcount表示最近一个语句影响的记录数;另一部分是与系统内部信息有关的全局变量,如@@version表示SQL Server的版本信息。

有关SQL Server中其它全局变量及其功能可参看系统帮助。

在UPDATA语句中使用@@rowcount变量来检测是否存在发生更改的记录。
USE SCC
GO
--将选修课程“1”的每个学生的成绩增加5分
UPDATE SC
SET grade= grade+5
WHERE cno ='1'
--如果没有发生记录更新,则发生警告信息
IF @@rowcount=0
Print '警告:没有发生记录更新!' /* Print语句将字符串返回给客户端*/

3.运算符

运算符是一种特殊符号,用来指定要在一个或多个表达式中执行的操作。

在SQL Server中的运算符: 算术运算符 、赋值运算符 、字符串连接运算符、 比较运算符 、逻辑运算符、 位运算符。

(1)算术运算符

Transact-SQL支持的算术运算符有:加(+)、减(-)、乘(*)、除(/)、取模(%)。

注意: 取模运算两边的表达式必须是整型数据。

(2)赋值运算符

赋值运算符(=)是将表达式的值赋给一个变量。它通常用于SET和SELECT语句中。

(3)字符串连接运算符

字符串连接运算符(+)用于将字符串或字符型变量串接起来。

说明: 默认情况下,对于varchar数据类型的数据,在连接VARCHAR、CHAR或TEXT类型的数据时,在默认设置情况下空的字符串被解释为空字符串,例如'abc'+''+'def'被存储为'abcdef'。但是,如果兼容级别设置为65,则空字符串将作为单个空白字符处理,'abc'+‘ '+'def'将被存储为'abc def'。

如果希望结果为‘abc def’,则可以使用space函数: ‘abc’+space(1)+‘def’

(4)比较运算符

Transact-SQL支持的比较运算符有:大于(>)、等于(=)、小于(<)、大于等于(>=)、小于等于(<=)、不等于(<>)、不等于(!=或<>)、不大于(!>)、不小于(!<)。

其中!=、!>、!<不是ANSI标准的运算符。

比较的结果是布尔数据类型,包括TRUE、FALSE和UNKNOWN。

(5)逻辑运算符

(6)位运算符

位运算符在两个表达式之间执行位操作,这两个表达式可以为整数数据类型或二进制数据类型(Image数据类型除外)。

位运算符包括:与(&)、或(|)、异或(^)、求反(~)等逻辑运算。

(7)在SQL Server中运算符的优先级

(1) ( )

(2) +(正)、-(负)、~(按位NOT)

(3) *(乘)、/(除)、%(模)

(4) +(加)、+(连接)、-(减)

(5) =、>、<、>=、<=、<>、!=、!>和!<(比较运算符)

(6) ^(位异或)、 &(位与)、|(位或)

(7) NOT

(8) AND

(9) OR、ALL、ANY、BETWEEN、IN、LIKE、SOME

(10) =(赋值)

4.函数

SQL Server提供了大量的内置系统函数,包括数学函数、字符串函数、数据类型转换函数和日期函数等几类。

SQL Server还支持用户定义函数,在系统函数不能满足需要的情况下,用户可以创建、修改和删除用户定义函数。

(1)内置系统函数

数学函数

分析比较下列语句的执行结果,正确理解CEILING(n)、FLOOR(n)、ROUND(n,m)三个数学函数的功能。
在SQL的查询窗口中输入:
SELECT ‘Select1’,CEILING(8.4),FLOOR(8.4),ROUND(8.456,2)
SELECT  ‘Select2’,CEILING(8.4),CEILING(-8.4)
SELECT  ‘Select3’,FLOOR(8.6),FLOOR(-8.6)

字符串函数

分析下列函数的执行结果,正确理解字符串函数的功能。
在SQL的查询窗口中输入:
SELECT REPLICATE('abc',3) 
SELECT REPLACE('abcdefgbcd','bcd','12')
SELECT STUFF('abcdefgbcd',2,4,'12')

数据类型转换函数

日期函数

查看当前日期为本年中的第几天。
print datepart(dy,getdate())

获取当前年份和当前月份。
SELECT YEAR(GETDATE() )
as 当前年份,MONTH(GETDATE()) as 月份

在StuInfo表中,查询所有年满19岁的学生学号、姓名、性别、年龄和所在系部。
SELECT  SID,Sname,Sex,DATEDIFF(yy,Birthday,GETDATE()) 
as Sge,Dept
FROM  StuInfo
Where DATEDIFF(yy,Birthday,GETDATE())>19

使用 CAST 数据类型转换函数Score转换为字符型,并实现字符串连接运算。
SELECT sno 
as 学号,‘成绩是:’ + CAST(grade  AS VARCHAR(3)) as 成绩
FROM sc
WHERE grade> 85 

(2)用户自定义函数

用户在编写程序的过程中,除了可以调用系统函数外,还可以根据应用需要自定义函数,以便用在允许使用系统函数的任何地方。

用户自定义函数包括表值函数和标量值函数两类,其中表值函数又包括内联表值函数和多语句表值函数。

标量值函数:返回一个确定类型的标量值。其返回类型为除TEXT、NTEXT、IMAGE、CURSOR、TIMESTAMP和TABLE类型以外的其他数据类型。函数体语句定义在BEGIN—END语句内。 内联表值函数:返回值是一个表。

内联表值函数没有由BEGIN—END语句括起来的函数体,其返回的表由一个位于RETURN语句中的SELECT语句从数据库中筛选出来。内联表值函数的功能相当于一个参数化的视图。

多语句表值函数:返回值是一个表。函数体包括多个SELECT语句,并定义在BEGIN…END语句内。

① 标量函数

创建标量函数语法格式:
CREATE  FUNCTION  function_name 
(@Parameter  scalar_ parameter_data_type[=default],[…n])
RETURNS  scalar_ return_data_type
AS
BEGIN
	Function  body
	RETURN  scalar _expresstion
END
参数说明:
function_name:指定要创建的函数名。
@Paramete:为函数指定一个或多个标量参数的名称。
scalar_ parameter_data_type:指定标量参数的数据类型。
default:指定标量参数的默认值。
scalar_ return_data_type:指定标量函数返回值的数据类型。
Function  body:指定实现函数功能的函数体。
scalar _expresstion:指定标量函数返回的标量值表达式。
创建一个标量函数,该函数返回两个参数的最大值。
CREATE  FUNCTION  My_Max(@X REAL,@Y REAL) 
RETURNS  REAL
AS
BEGIN
	DECLARE @Z REAL
	IF @X>@Y
     SET @Z=@X
    ELSE
     SET @Z=@Y
 RETURN(@Z)
END

②内联表值函数

创建内联表值函数语法格式如下:
CREATE  FUNCTION  function_name 
(@Parameter  scalar_ parameter_data_type[=default],[…n])
RETURNS  TABLE
AS
RETURN  select_stmt
参数说明:
TABLE:指定返回值为一个表
select_stmt:单条SELECT语句,确定返回表的数据。
其余参数与标量函数相同。


在TeachingData数据库中创建一个内联表值函数,该函数返回高于指定成绩的查询信息。
CREATE  FUNCTION  greaterScore (@cj FLOAT)
RETURNS  TABLE
AS
RETURN  SELECT  *
          FROM Sc
          WHERE grade>=@cj

③ 多语句表值函数

创建多语句表值函数语法格式如下:
CREATE  FUNCTION  function_name 
(@Parameter  scalar_ parameter_data_type[=default],[…n])
RETURNS  table_varible_name TABLE
(<colume_definition>)
AS
BEGIN
function_body
RETURN
END
参数说明:
table_varible_name:指定返回的表变量名。
colume_definition :返回表中各个列的定义。

调用用户自定义函数

① 调用标量函数

当调用用户自定义的标量函数时,提供由两部分组成的函数名称,即所有者.函数名,自定义函数的默认所有者为dbo。 可以利用PRINT、SELECT和EXEC语句中调用标量函数。

②调用表值函数

表值函数只能通过SELECT语句调用,在调用时可以省略函数的所有者。 内联表值函数和多语句表值函数的调用方法相同。

使用不同的方式调用my_Max标量函数。
用Print语句调用标量函数
PRINT dbo.my_max(3,6)
用Select语句调用标量函数
SELECT dbo.my_max(3,6)
用EXEC语句调用标量函数
DECLARE @m REAL
EXEC @m=dbo.my_max 3,6
PRINT @m

在使用EXEC调用自定义函数时,调用参数的次序与函数定义中的参数次序可以不同,此时必须用赋值号为函数的标量参数指定相应的实参。例如:
DECLARE @m REAL
EXEC @m=dbo.my_max @y=15,@x=2
PRINT @m
GO

利用内联表值函数Score查询成绩大于90分的成绩信息。
SELECT * 
FROM greaterScore(90)

3.T-SQL编程

1.批处理

批处理是指将一条或多条Transact-SQL语句归纳为一组,以便一起提交到SQL Server执行。

SQL Server将批处理语句编译成一个可执行单元,此单元称为执行计划。每次执行一条语句。批处理以GO语句作为结束符。

在批处理中,由于语法错误等问题而造成编译错误,将使执行计划无法编译,而且批处理中的所有语句不被执行。

INSERT INTO ScoreInfo (SID,CID,TID,Score)
VALUES('06010001','00000002','01000001',87)
INSERT INTO ScoreInfo (SID,CID, TID,Score)
Go
当上述批处理被执行时,首先进行批处理编译,第一条INSERT语句被编译,第二条INSERT语句由于缺少VALUES子句存在语法错误而不被编译。因此整个批处理的语句不被执行。

如果是由于数据溢出或违反约束等原因造成的运行时错误,则处理方式如下:

大多数的运行时错误会停止执行发生错误的语句,而且当前批处理中该语句之后的所有语句也不执行。 少数的运行时错误(如违反约束)仅会停止执行发生错误的语句,而且当前批处理中该语句之后的所有语句仍会继续执行。

INSERT INTO ScoreInfo (SID,CID,TID,Score)
VALUES('06010001','00000002','01000001',87)
INSERT INTO ScoreInfo (SID,CID, TID,Score)
VALUES('05010002','00000001','01000001','男')
GO
当上述批处理被执行时,首先能成功进行编译,接下来由于第二条INSERT语句在执行时失败,则第一条语句的执行结果不受影响,因为它已经执行。

2.流程控制语句

BEGIN…END语句

BEGIN…END语句用于将多个Transact-SQL语句组合成一个语句块,以便将它们视为一个整体来处理。

在条件语句和循环语句等控制流程中,当符合特定条件便执行两条或两条以上的T-SQL语句时,需要使用BEGIN…END语句将它们组合成一个语句块。

语法格式:
BEGIN
{sql_statement | statement_block}
END
其中sql_statement | statement_block是指所包含的T-SQL语句或语句块。

例如下面的代码中,由于符合IF表达式的条件需要执行两条语句,因此必须使用BEGIN…END语句将这两条语句组合成一个语句块:
DECLARE @ErrorNumber INT
IF (@@ERROR<>0)
   BEGIN
      SET @ErrorNumber=@@ERROR
      PRINT '错误代码是:'+CAST(@ErrorNumber AS VARCHAR(10))
   END

BEGIN…END语句会经常在WHILE语句、CASE函数、IF…ELSE语句中被用到,而且BEGIN…END语句允许嵌套使用。

从SC表中查找学号为’201215121’的同学的各科成绩,如果选修课程全部及格,则输出各门课程全部及格,否则输出该同学不及格课程的门数。
DECLARE @n INT;
IF (SELECT min(grade) FROM SC
WHERE SNO='201215121' GROUP BY SNO)>=60
   print '该同学的各门课程全部及格!'
ELSE
   BEGIN
      SELECT @n=COUNT(CNO) FROM SC
WHERE SNO='201215121' AND grade<60
      print '该同学有'+CAST(@n AS VARCHAR)+'门课程不及格!'
   END

IF…ELSE

IF…ELSE语句是条件判断语句。利用该语句使程序具有不同条件的分支,以完成执行各种不同条件下的操作功能操作。

其语法格式如下:
IF Boolean_expression 
{ sql_statement1 | statement_block1 } 
[ ELSE 
{ sql_statement2| statement_block2 } ] 

说明:

(1)ELSE子句可选,最简单的IF 语句没有ELSE 子句部分。

(2)如果不使用BEGIN…END语句,IF或ELSE只能执行一条语句。

(3)IF…ELSE 可以进行嵌套,可实现多重条件的选择。在Transact-SQL 中最多可嵌套32 级。 

CASE

虽然使用IF语句嵌套可以实现多重条件的选择,但是比较繁琐。SQL Server提供了一个简单的方法,那就是CASE函数。

CASE函数按其使用形式的不同,可以分为简单CASE函数和搜索CASE函数。

简单CASE函数必须以CASE开头,以END结束。它能够将一个指定表达式与一系列简单表达式进行比较,并且返回符合条件的结果表达式。语法格式:
CASE  input_expression 
WHEN when_expression THEN result_expression 
[ ...n ] 
[ELSE else_result_expression ] 
END 
参数说明:
input_expression:指定计算表达式。
when_expression:指定比较表达式。input_expression的值依次与每个WHEN子句中的when_expression的值进行比较。
result_expression:指定结果表达式。当input_expression的值与when_expression的值相等时,返回的表达式。
else_result_expression:指定当input_expression的值与所有的when_expression的值比较结果均为假时,返回的表达式。

注意:

(1) CASE函数中的各个when_expression的数据类型必须与input_expression的数据类型相同,或者是可以隐式转换的数据类型。

(2) CASE函数中如果多个WHEN子句when_expression的值与input_expression的值相同,则只会返回第一个与input_expression值相同的when_expression对应的result_expression的值。

函数执行顺序:

① 首先计算input_expression,然后按指定顺序对每个WHEN子句中when_expression的值与input_expression的值进行比较;

② 如果比较结果为TRUE,则返回当前WHEN子句对应的result_expression,然后跳出CASE函数;

③ 如果没有任何一个WHEN子句when_expression的值与input_expression的值相同,SQL Server检查是否有ELSE子句,如果有便返回else_result_expression,否则返回NULL。

从Student表中,显示学生的学号(SNO)、姓名(Sname)和性别(SSex),如果性别为“男”显示“M”, 性别为“女”则显示“F”。
SELECT sno as 学号,Sname as 姓名,性别= 
CASE SSex
    WHEN '男' THEN 'M'
    WHEN '女' THEN 'F'
END 
FROM Student

搜索CASE函数:

搜索CASE函数的语法格式为:
CASE
WHEN Boolean_expression THEN result_expression 
[ ...n ] 
[ELSE else_result_expression ] 
END
参数说明:
Boolean_expression:条件表达式,结果为逻辑值。

搜索CASE函数的执行顺序:

① 首先按指定顺序依次计算每个WHEN子句的Boolean_expression的值。

② 返回第一个取值为TRUE的WHEN子句对应的result_expression,然后跳出CASE语句。

③ 如果所有WHEN子句后的Boolean_expression都为FALSE,SQL Server检查是否有ELSE子句,如果有则返回else_result_expression,否则返回NULL。

从Sc表中查询所有同学选课成绩情况,将百分制转换为五分制:凡成绩大于或等于90分时显示“优秀”;80分至90分显示“良好”;70分至80分显示“中等”;60分至70分显示“及格”; 小于60分显示“不及格”;为空者显示“未考”。
SELECT SNO, CNO,GRADE, 等级=
CASE  
        WHEN GRADE >=90 THEN '优秀'
        WHEN GRADE >=80  THEN '良好'
        WHEN GRADE >=70  THEN '中等'
        WHEN GRADE >=60  THEN '及格'
        WHEN GRADE<60 THEN '不及格' 
        WHEN GRADE IS NULL THEN '未考' 
   END  
FROM Sc

WHILE…CONTINUE…BREAK

WHILE语句用于设置重复执行SQL语句或语句块的条件。只要设定的条件为TRUE,就重复执行命令行或程序块。

其语法格式如下:
WHILE Boolean_expression 
BEGIN
{ sql_statement | statement_block } 
[ BREAK ]
[ CONTINUE ]
{ sql_statement | statement_block } 
END

其中CONTINUE和BREAK语句可以控制WHILE循环中语句的执行。CONTINUE语句可以让程序跳过CONTINUE命令之后的所有语句,回到WHILE循环的第一行,继续进行下一次循环。BREAK语句则使程序跳出循环,结束WHILE语句的执行。

编写Transact-SQL程序,计算20~100的累加和,如果累加和大于等于2000则结束循环,并输出结果。
DECLARE @sum INT,@i int
SET @sum=0
SET @i=20
WHILE  @i<=100
   BEGIN
      SET @sum=@sum+@i
      IF @sum>=2000
         BREAK
      SET @i=@i+1
   END
PRINT '20~'+CAST(@i as VARCHAR(2))+'的累加和sum='+STR(@sum)

WAITFOR

WAITFOR语句又称为延迟语句,用于指定触发器、存储过程或事务执行的时间或时间间隔;还可以暂停程序的运行,直到所设定的等待时间已过或所设定的时间已到才继续往下执行。

其语法格式如下:
WAITFOR 
{ DELAY 'time_to_pass' | TIME 'time_to_execute' }
参数说明: 
DELAY:指定可以继续执行批处理、存储过程或事务之前必须经过的等待时间间隔。
time_to_pass:指定等待的时间间隔,最长设定为24小时。
TIME:指定运行批处理、存储过程或事务的时间点。
time_to_execute:指定WAITFOR语句的完成时间。

注意:time_to_pass 和time_to_execute 必须是DATETIME数据类型。如“1:10:00”,但不能包括日期。

等待5秒钟后执行SELECT语句。
WAITFOR DELAY '0:0:5'
SELECT * FROM Student

GOTO

GOTO 语句用来改变程序执行的流程,使程序流程跳到指定的标识符,跳过GOTO语句后面的语句,并从标签符位置继续进行。

GOTO语句和标识符可以用在语句块、批处理和存储过程中的任意位置使用。

作为跳转目标的标识符可以是数字与字符的组合。但必须以“:”结尾,在GOTO 语句行,标识符后不必跟“:”。

其语法格式如下: GOTO label

use teachingdata
declare @stuscore tinyint
declare @returnstr varchar(50)
select @stuscore=score
from scoreinfo
where sid='05000001' and cid='00100002'
if @stuscore<60
goto notpass
if @stuscore<86
goto pass
if @stuscore<=100
goto good
goto other

notpass:
print '很遗憾,未通过考试'
goto theend
pass:
print '恭喜你,已通过考试'
goto theend
good:
print '成绩优秀,你真棒'
goto theend
other:
print '成绩输入有误!'
goto theend

theend:

RETURN

RETURN 语句用于从查询或过程中无条件退出。此时位于该语句后的语句将不再被执行,返回到上一个调用它的程序或其它程序。

其语法格式如下:
RETURN [ integer_expression ] 
参数说明:
integer_expression:用于指定一个返回值,要求是整型表达式。integer_expression部分可选,如果省略,SQL Server 系统会根据程序执行的结果返回一个内定值。 

内定含义:

3.错误捕获语句

为了增强程序的健壮性,必须对程序中可能出现的错误进行及时的处理。

在T-SQL语句中,可以使用TRY…CATCH语句和@@ERROR函数两种方式处理发现的错误。

(1)TRY…CATCH

TRY…CATCH语句是SQL Server 2005新增的功能语句,它类似于C++中的异常处理。Transact-SQL 语句组可以包含在 TRY 块中,当执行TRY语句组中的语句出现错误时,系统将会把控制传递给CATCH块中包含的另一个语句组处理。

其语法格式如下:
BEGIN TRY
{ sql_statement | statement_block }
END TRY
BEGIN CATCH
{ sql_statement | statement_block }
END CATCH
参数说明:
sql_statement | statement_block:表示任何Transact -SQL语句、批处理,或包括于BEGIN…END块中的语句组。

说明:

(1) 必须在BEGIN TRY…END TRY语句块后紧跟着相关的BEGIN CATCH…END CATCH语句块。如果有位于这两个语句块之间的语句,将会产生错误;

(2) 每个BEGIN TRY…END TRY语句块只能与一个BEGIN CATCH…END CATCH语句块相关联。

向StuInfo表中插入两条记录,第二条记录学号SID已经存在,观察捕捉的错误信息。
BEGIN TRY
   INSERT StuInfo(SID,Sname)
      VALUES('09011101','汪洋')
   INSERT StuInfo(SID,Sname)
      VALUES(' 04000002','李少华')
END TRY
BEGIN CATCH
   SELECT  ERROR_NUMBER() AS ErrorNumber,  --返回错误号
            ERROR_SEVERITY() AS ErrorSeverity, --返回严重性
            ERROR_STATE() AS ErrorState,       --返回错误状态号
            ERROR_LINE() AS ErrorLine,         --返回导致错误的例程中的行号
            ERROR_MESSAGE() AS ErrorMessage;  --返回错误消息的完整文本
END CATCH;

(2)@@ERROR函数

@@ERROR函数用于捕捉上一条T-SQL语句的错误号。由于@@ERROR在每一条语句执行后被清除并且重置,因此应在语句执行后立即查看它,或将其保存到一个局部变量中以备以后查看。

如果前一个Transact-SQL语句执行没有错误,则返回0。否则返回错误代号。

用@@ERROR在UPDATE语句中检测约束检查冲突(错误 #547)。
USE TeachingData
GO
UPDATE ScoreInfo 
SET CID ='70000004'
WHERE SID='04000002'AND TID='01000003'
IF @@ERROR = 547
PRINT N'违反了约束冲突!'
GO

4.注释

注释是指程序中用来说明程序内容的语句,它不执行而且也不参与程序的编译。

通常是对代码功能给出简要解释或提示的一些说明性的文字,有时也用于暂时禁用的部分Transact -SQL语句或语句块。

在程序中使用注释一个程序员的良好编程习惯,它不但可以帮助他人了解自己编写程序的具体内容,而且还可以便于对程序总体结构的掌握。

SQL Server 2005支持两种语法形式表示注释内容:单行注释、块注释

1.单行注释

使用两个连字符“--”作为注释的开始标志,到本行行尾即最近的回车结束之间的所有内容为注释信息。该注释符可与要执行的代码处在同一行,也可另起一行。

USE TeachingData     --打开TeachingData数据库
GO 
--检索StuInfo表的数据
SELECT *
FROM  StuInfo
GO 

2.块注释

块注释的格式为/*……*/,其间的所有内容均为注释信息。块注释与单行注释不同的是它可以跨越多行,并且可以插入在程序代码中的任何地方。

USE TeachingData   
DECLARE @Cname VARCHAR(8)  /*定义变量@Cname */
/*定义变量
把查询的结果赋给变量*/
SELECT @Cname=Cname FROM CourseInfo
  WHERE CID='00000001' 
GO

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/668241.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AIGC全面揭秘:人工智能内容生成的无限可能!

一、引言 随着人工智能技术的不断发展&#xff0c;AIGC&#xff08;人工智能生成内容&#xff09;技术逐渐受到广泛关注。本文将全面介绍AIGC的相关知识。 二、AIGC简介 AIGC是利用人工智能技术自动生成内容的一种技术。它可以根据给定的输入数据和规则&#xff0c;自动产生符…

详解 Spark 编程之 RDD 依赖关系

一、依赖与血缘关系 依赖&#xff1a;两个相邻 RDD 之间的关系血缘关系&#xff1a;多个连续的 RDD 的依赖由于 RDD 不会保存数据&#xff0c;为了提高容错性&#xff0c;每个 RDD 都会保存自己的血缘关系&#xff0c;一旦某个转换过程出现错误&#xff0c;可以根据血缘关系重新…

开源VS闭源:AI未来的十字路口

人工智能领域的发展日益加速&#xff0c;其中关于模型的开源和闭源策略引起了业界的广泛关注。开源策略指的是将软件的源代码公开&#xff0c;允许任何人自由使用、研究甚至改进&#xff1b;而闭源策略则是指软件的源代码不公开&#xff0c;只有特定的个体或组织有权访问和修改…

【IPFS应用开发】基于IPFS的视频播放器

本系列文章是针对 https://blog.csdn.net/weixin_43668031/article/details/83962959 内容的实现所编写的。开发经历包括思考过程、重构和推翻重来。 基于IPFS的视频播放器 想写一个真正的、基于IPFS的&#xff0c;可以播放IPFS上的视频的程序支持多种数据加载格式同时支持单文…

docker部署Minio对象存储及使用

1.拉取镜像 docker pull minio/minio2.创建数据目录 mkdir -p /data/minio/data3.启动容器 docker run -p 39000:9000 -p 39090:9090 \ --name minio \ -d --restartalways \ -e "MINIO_ACCESS_KEYjyadmin" \ -e "MINIO_SECRET_KEYjyzx2023" \ -v /data…

C++数据结构之:链List

摘要&#xff1a; it人员无论是使用哪种高级语言开发东东&#xff0c;想要更高效有层次的开发程序的话都躲不开三件套&#xff1a;数据结构&#xff0c;算法和设计模式。数据结构是相互之间存在一种或多种特定关系的数据元素的集合&#xff0c;即带“结构”的数据元素的集合&am…

用esp prog烧录ESP32-C3板踩坑

附ESP32C3的GPIO一览&#xff1a; vscode选择Jtag烧录&#xff0c;终端输出esp_usb_jtag: could not find or open device&#xff1a; D:\Devtools\Espressif\tools\openocd-esp32\v0.12.0-esp32-20230921\openocd-esp32\bin\openocd.exe -f board/esp32s3-builtin.cfgOpen O…

xxl-job的使用

介绍 在分布式中&#xff0c;很多微服务可能存在多实例部署的现象&#xff0c;如果在某个具体的微服务中实现一个定时任务&#xff0c;而该微服务存在多个实例的话&#xff0c;那么会导致该定时任务在不同实例中都会进行执行&#xff01;这很容易导致脏数据、数据重复等问题&am…

黑白群晖激活AME(Advanced Media Extention)

黑群晖激活Advanced Media Extensions&#xff08;AME&#xff09;解码HEVC视频和HEIC图片 声明&#xff1a;此教程在正版群晖系统中进行的操作&#xff0c;虽然也能用于非正版系统中AME的安装&#xff0c;但是在非正版系统中安装AME属于破解行为&#xff0c;对系统造成的影响和…

安装vllm的时候卡主:Collecting vllm-nccl-cu12<2.19,>=2.18 (from vllm)

按照vllm的时候卡主&#xff1a; ... Requirement already satisfied: typing-extensions in /home/wangguisen/miniconda3/lib/python3.10/site-packages (from vllm) (4.9.0) Requirement already satisfied: filelock>3.10.4 in /home/wangguisen/miniconda3/lib/python…

落地台灯有什么作用?五款口碑好的落地台灯推荐

落地台灯有什么作用&#xff1f;面对长时间工作、学习已成为当代年轻人的真实写照&#xff0c;据目前不完全统计&#xff0c;60%以上的人群每天用眼时间都已经超过10小时&#xff0c;高强度的的用眼以及不可确定的环境因素都易导致双眼出现干涉、酸痛、红血丝等情况&#xff0c…

SpringBoot 七牛云 OSS 私有模式 获取访问链接

目录 一、问题引出 二、在SpringBoot中获取私有访问路径的操作 一、问题引出 由于七牛云OSS的公有模式存在被盗刷的风险&#xff0c;可能导致服务器额外的费用&#xff0c;于是我选择私有模式进行操作。私有模式的访问路径是一个问题&#xff0c;因为需要对应着token和e这两…

MyBatis系统学习篇 - 分页插件

MyBatis是一个非常流行的Java持久层框架&#xff0c;它简化了数据库操作的代码。分页是数据库查询中常见的需求&#xff0c;MyBatis本身并不直接支持分页功能&#xff0c;但可以通过插件来实现&#xff0c;从而帮助我们在查询数据库的时候更加方便快捷 引入依赖 <dependen…

Python 学习笔记【1】

此笔记仅适用于有任一编程语言基础&#xff0c;且对面向对象有一定了解者观看 文章目录 数据类型字面量数字类型数据容器字符串列表元组 type()方法数据类型强转 注释单行注释多行注释 输出基本输出连续输出&#xff0c;中间用“,”分隔更复杂的输出格式 变量定义del方法 标识符…

LeetCode84:柱形图中最大的矩形

题目描述 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 代码 单调栈 class Solution { public:int largestRectangleArea(vector<int>& h…

【数据结构】链表与顺序表的比较

不同点&#xff1a; 顺序表和链表是两种常见的数据结构&#xff0c;他们的不同点在于存储方式和插入、删除操作、随机访问、cpu缓存利用率等方面。 一、存储方式不同: 顺序表&#xff1a; 顺序表的存储方式是顺序存储&#xff0c;在内存中申请一块连续的空间&#xff0c;通…

文明互鉴促发展——2024“国际山地旅游日”主题活动在法国启幕

5月29日&#xff0c;2024“国际山地旅游日”主题活动在法国尼斯市成功举办。中国驻法国使领馆、法国文化旅游部门、地方政府、国际组织、国际山地旅游联盟会员代表、旅游机构、企业、专家、媒体等围绕“文明互鉴的山地旅游”大会主题和“气候变化与山地旅游应对之策”论坛主题展…

字符串-最长回文子串

一、题目描述 二、解题思路 设置双指针&#xff0c;定位连续子串&#xff0c;这里提供暴力解法&#xff0c;枚举各种子串并判断子串是否符合回文特征&#xff0c;符合则更新最长子串长度。 主要是注意一下java相关的语法API&#xff1a; 1.使用 (new StringBuilder(substr))…

MongoDB~存储引擎了解

存储引擎 存储引擎是一个数据库的核心&#xff0c;主要负责内存、磁盘里数据的管理和维护。 MongoBD的优势&#xff0c;在于其数据模型定义的灵活性、以及可拓展性。但不要忽略&#xff0c;其存储引擎也是插件式的存在&#xff0c;支持不同类型的存储引擎&#xff0c;使用不同…

B-TREE教程(个人总结版)

背景 在计算机科学中&#xff0c;数据存储和检索的效率是一个重要的研究课题。B-树&#xff08;B-Tree&#xff09;作为一种自平衡树结构&#xff0c;特别适合于在磁盘存储中处理大规模数据。它通过保持树的高度平衡&#xff0c;使得搜索、插入和删除操作的时间复杂度保持在对…