📄 12-2-1.cfm.htm
字号:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>Transact</title>
<meta name="GENERATOR" content="Microsoft FrontPage 3.0">
</head>
<body>
<font FACE="宋体" SIZE="5"><b>
<p ALIGN="JUSTIFY">Transact-SQL编程</p>
</b></font><font FACE="宋体" SIZE="3">
<p ALIGN="JUSTIFY">在下面部分的许多语句都不是SQL标准语句,而是一个叫做Transact-SQL(T-SQL)的SQL扩展的一部分。T-SQL通过在别的事物上添加一些诸如变量、条件和循环之类的传统编程元素来扩充SQL。</p>
<p ALIGN="JUSTIFY">你可能注意到这个问题的唯一原因是你计划使用一种和Microsoft
SQL Server不同的数据库服务器。在下面部分介绍的语句和技术并不是所有都是可替换的。然而,如果你想全面的利用Microsoft
SQL Server的性能,你必须使用T-SQL。</p>
</font><font FACE="宋体"><b>
<p ALIGN="JUSTIFY">在批处理中执行多个语句</p>
</b></font><font FACE="宋体" SIZE="3">
<p ALIGN="JUSTIFY">为了一次能够执行多个SQL语句,你可以把它们一起放入一个批处理中。批处理,如同它的名字所隐含的意识一样,是简单的一个或多个SQL语句组成的语句组。比如,假如你在ISQL/w中输入下面的两个语句,它们就会做为一个批处理而一起执行:</p>
<p ALIGN="JUSTIFY">SELECT pub_name FROM publishers</p>
<p ALIGN="JUSTIFY">SELECT pub_name FROM publishers</p>
<p ALIGN="JUSTIFY">当你执行上面那个简单的批处理时,在表中同样的数据被读取了两次---一个SELECT
语句读取一次。现在假设你输错了第二个SELECT语句中表的名称,并尝试执行下面的语句:</p>
<p ALIGN="JUSTIFY">SELECT pub_name FROM publishers</p>
<p ALIGN="JUSTIFY">SELECT ub_name FROM publishers</p>
<p ALIGN="JUSTIFY">你可能期望第一个语句能够成功执行,而在执行第二个语句时会发生错误。而实际上并不是这样,在大多数情况下,如果在批处理中有任何一个语句不能成功执行。在其中没有一个语句会执行(特殊情况请看下面的注意)。SQL
Server 把在批处理中的语句当成组来看待。</p>
<b>
<p ALIGN="JUSTIFY">注意</p>
</b></font><font SIZE="3">
<p ALIGN="JUSTIFY"></font><font FACE="宋体" SIZE="3">在一些情况下,一个语句在发生错误时,其他语句仍然能够执行。假如服务器在传递和编译一个批处理时检测到错误,则在批处理中的所有语句都不能执行。假如批处理通过了编译但仍然存在错误,则在其中的某些语句就可能会执行。</p>
<p ALIGN="JUSTIFY">你可以把一组语句分成隔离的批处理。在ISQL/w中,你可以使用命令GO来实现该功能。考察下面的语句:</p>
<p ALIGN="JUSTIFY">SELECT pub_name FROM publishers</p>
<p ALIGN="JUSTIFY">GO</p>
<p ALIGN="JUSTIFY">SELECT ub_name FROM publishers</p>
<p ALIGN="JUSTIFY">假如你在ISQL/w中执行上面的语句。即使在第二个SELECT语句中存在错误。第一个语句仍然能够成功地返回答案集。GO命令强迫SQL
Server 将此二个语句看成两个批处理。</p>
</font>
</body>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -