存储过程语法知识2
上一篇 / 下一篇 2008-04-28 14:25:14 / 个人分类:数据库
51Testing软件测试网4u d T~T
51Testing软件测试网RR0Cz-B-G-t9\7u$Y51Testing软件测试网&]pz@8T
kNL1oFr8a
FOR REPLICATION51Testing软件测试网$i4CLo |[zM'r g2V
指定不能在订阅服务器上执行为复制创建的存储过程。.使用 FOR REPLICATION 选项创建的存储过程可用作存储过程筛选,且只能在复制过程中执行。本选项不能和 WITH RECOMPILE 选项一起使用。
zN3pxwPx2J O0L4I}KB)vH^#L0AS51Testing软件测试网:Q2W2z2[J j]0~:`j
v8K'n]"r*t0指定过程要执行的操作。
(v QuQ!F!m0!WKD4oQQ0sql_statement
zw+^:n1qw051Testing软件测试网.~qc){y5z+y过程中要包含的任意数目和类型的 Transact-SQL 语句。但有一些限制。51Testing软件测试网eT"a6pI7G
51Testing软件测试网i][2N X!` m.Mn51Testing软件测试网s#A3~.S+k7mQ,i8aM
|F,R*Dw6l^mP0是表示此过程可以包含多条 Transact-SQL 语句的占位符。
SY5HKf8Rk P v09h-t5C`
y0注释51Testing软件测试网*v1x^9{+Jb%[7O8k
^ q
存储过程的最大大小为 128 MB。
I:?&LF&WB,O0用户定义的存储过程只能在当前数据库中创建(临时过程除外,临时过程总是在 tempdb 中创建)。在单个批处理中,CREATE PROCEDURE 语句不能与其它 Transact-SQL 语句组合使用。51Testing软件测试网@OQ v+f9j~
2L+S{#}}#bY l0默认情况下,参数可为空。如果传递 NULL 参数值并且该参数在 CREATE 或 ALTER TABLE 语句中使用,而该语句中引用的列又不允许使用 NULL,则 SQL Server 会产生一条错误信息。为了防止向不允许使用 NULL 的列传递 NULL 参数值,应向过程中添加编程逻辑或为该列使用默认值(使用 CREATE 或 ALTER TABLE 的 DEFAULT 关键字)。51Testing软件测试网.M,m,Ba,@
51Testing软件测试网&OpG[%B(K;C建议在存储过程的任何 CREATE TABLE 或 ALTER TABLE 语句中都为每列显式指定 NULL 或 NOT NULL,例如在创建临时表时。ANSI_DFLT_ON 和 ANSI_DFLT_OFF 选项控制 SQL Server 为列指派 NULL 或 NOT NULL 特性的方式(如果在 CREATE TABLE 或 ALTER TABLE 语句中没有指定的话)。如果某个连接执行的存储过程对这些选项的设置与创建该过程的连接的设置不同,则为第二个连接创建的表列可能会有不同的为空性,并且表现出不同的行为方式。如果为每个列显式声明了 NULL 或 NOT NULL,那么将对所有执行该存储过程的连接使用相同的为空性创建临时表。51Testing软件测试网Ut"]P%u ^TC
51Testing软件测试网 atBX| Ik~在创建或更改存储过程时,SQL Server 将保存 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 的设置。执行存储过程时,将使用这些原始设置。因此,所有客户端会话的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 设置在执行存储过程时都将被忽略。在存储过程中出现的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 语句不影响存储过程的功能。
Kz;Oyd2I0H&siU y Jt5PU0其它 SET 选项(例如 SET ARITHABORT、SET ANSI_WARNINGS 或 SET ANSI_PADDINGS)在创建或更改存储过程时不保存。如果存储过程的逻辑取决于特定的设置,应在过程开头添加一条 SET 语句,以确保设置正确。从存储过程中执行 SET 语句时,该设置只在存储过程完成之前有效。之后,设置将恢复为调用存储过程时的值。这使个别的客户端可以设置所需的选项,而不会影响存储过程的逻辑。51Testing软件测试网rwv!D,yZ;i.s
51Testing软件测试网5h!]0b!a8wu9V
J]y@f]7g051Testing软件测试网 Y-L(L$kQ^~&^\3n
说明 SQL Server 是将空字符串解释为单个空格还是解释为真正的空字符串,由兼容级别设置控制。如果兼容级别小于或等于 65,SQL Server 就将空字符串解释为单个空格。如果兼容级别等于 70,则 SQL Server 将空字符串解释为空字符串。有关更多信息,请参见 sp_dbcmptlevel。
V,po+f#mY'uK0
SeGz|0获得有关存储过程的信息51Testing软件测试网x(\1b9SZa+|RM
若要显示用来创建过程的文本,请在过程所在的数据库中执行 sp_helptext,并使用过程名作为参数。51Testing软件测试网;_B0[1PS2e
kN7\q8gV%rop)u&K B051Testing软件测试网AERfmo v
说明 使用 ENCRYPTION 选项创建的存储过程不能使用 sp_helptext 查看。51Testing软件测试网hNoA%E0V\,JAD/t
@0glF$v|8T'p0若要显示有关过程引用的对象的报表,请使用 sp_depends。51Testing软件测试网Xm |p:n
%txO2y-L6eq0若要为过程重命名,请使用 sp_rename。51Testing软件测试网;Ir"^)[;J
2fk{?W%w,g_yf;F0引用对象
6RhNj&Y0SQL Server 允许创建的存储过程引用尚不存在的对象。在创建时,只进行语法检查。执行时,如果高速缓存中尚无有效的计划,则编译存储过程以生成执行计划。只有在编译过程中才解析存储过程中引用的所有对象。因此,如果语法正确的存储过程引用了不存在的对象,则仍可以成功创建,但在运行时将失败,因为所引用的对象不存在。有关更多信息,请参见延迟名称解析和编译。
延迟名称解析和兼容级别
;y|Hd.}6yZD6PVSc051Testing软件测试网2Z&WK*]cc&d#r3K'tSQL Server 允许 Transact-SQL 存储过程在创建时引用不存在的表。这种能力称为延迟名称解析。不过,如果 Transact-SQL 存储过程引用了该存储过程中定义的表,而兼容级别设置(通过执行 sp_dbcmptlevel 来设置)为 65,则在创建时会发出警告信息。而如果在运行时所引用的表不存在,将返回错误信息。有关更多信息,请参见 sp_dbcmptlevel 和延迟名称解析和编译。51Testing软件测试网6M/|`"jmrH^
I(ymrl0
yI9W$jC*a0-W8a#@&sko1c'nv0执行存储过程
I%S4jU'G3~6S9[0成功执行 CREATE PROCEDURE 语句后,过程名称将存储在 sysobjects 系统表中,而 CREATE PROCEDURE 语句的文本将存储在 syscomments 中。第一次执行时,将编译该过程以确定检索数据的最佳访问计划。51Testing软件测试网)B7W;Hu"P)W
使用 cursor 数据类型的参数
i3kwc4l0存储过程只能将 cursor 数据类型用于 OUTPUT 参数。如果为某个参数指定了 cursor 数据类型,也必须指定 VARYING 和 OUTPUT 参数。如果为某个参数指定了 VARYING 关键字,则数据类型必须是 cursor,并且必须指定 OUTPUT 关键字。
2E(Z%|,@O? ~ T,q0说明 cursor 数据类型不能通过数据库 API(例如 OLE DB、ODBC、ADO 和 DB-Library)绑定到应用程序变量上。因为必须先绑定 OUTPUT 参数,应用程序才可以执行存储过程,所以带有 cursor OUTPUT 参数的存储过程不能通过数据库 API 调用。只有将 cursor OUTPUT 变量赋值给 Transact-SQL 局部 cursor 变量时,才可以通过 Transact-SQL 批处理、存储过程或触发器调用这些过程。
51Testing软件测试网_/[ d Yb)e^u
Cursor 输出参数51Testing软件测试网/_;XC*G-Iq
在执行过程时,以下规则适用于 cursor 输出参数:51Testing软件测试网:zu$\q6Uow
对于只进游标,游标的结果集中返回的行只是那些存储过程执行结束时处于或超出游标位置的行,例如:51Testing软件测试网3}u$J3cg#IV
在过程中的名为 RS 的 100 行结果集上打开一个非滚动游标。51Testing软件测试网/M6rC:r){
n,](_-I
[tFO051Testing软件测试网y)}1V
z&itR({Q
过程提取结果集 RS 的头 5 行。
#x#r\O7q/[,i0
0G.P u4SF7Z `t%VV0过程返回到其调用者。51Testing软件测试网}%zm]`;n
L[2b
RG-x(V'X/{
co }0返回到调用者的结果集 RS 由 RS 的第 6 到 100 行组成,调用者中的游标处于 RS 的第一行之前。
qh9]E'^7Y4` BQs7g]0对于只进游标,如果存储过程完成后,游标位于第一行的前面,则整个结果集将返回给调用批处理、存储过程或触发器。返回时,游标将位于第一行的前面。
O3[hR};]051Testing软件测试网9i q2Mh6g6Q`%[
对于只进游标,如果存储过程完成后,游标的位置超出最后一行的结尾,则为调用批处理、存储过程或触发器返回空结果集。51Testing软件测试网Y@dG6`4E|hUy;r
I$w&? DH2l(Jvf(q0说明 空结果集与空值不同。
;l5T}p.~perP051Testing软件测试网}7S@F{I?对于可滚动游标,在存储过程执行结束时,结果集中的所有行均会返回给调用批处理、存储过程或触发器。返回时,游标保留在过程中最后一次执行提取时的位置。51Testing软件测试网4|ZW%~vb3}c
51Testing软件测试网-ZT?o1v
7?
}8X`)Qj%K'wP0对于任意类型的游标,如果游标关闭,则将空值传递回调用批处理、存储过程或触发器。如果将游标指派给一个参数,但该游标从未打开过,也会出现这种情况。51Testing软件测试网.k1}l+||!S-G
说明 关闭状态只有在返回时才有影响。例如,可以在过程中关闭游标,稍后再打开游标,然后将该游标的结果集返回给调用批处理、存储过程或触发器。
0~7^1LN8|051Testing软件测试网$k*?;F|s'iT51Testing软件测试网'yKxj;Uo\&`%U$T\
临时存储过程51Testing软件测试网3j0K7v\:i}kU#N
SQL Server 支持两种临时过程:局部临时过程和全局临时过程。局部临时过程只能由创建该过程的连接使用。全局临时过程则可由所有连接使用。局部临时过程在当前会话结束时自动除去。全局临时过程在使用该过程的最后一个会话结束时除去。通常是在创建该过程的会话结束时。51Testing软件测试网1na"v*k{(t9y
![yMK&H2^(s0临时过程用 # 和 ## 命名,可以由任何用户创建。创建过程后,局部过程的所有者是唯一可以使用该过程的用户。执行局部临时过程的权限不能授予其他用户。如果创建了全局临时过程,则所有用户均可以访问该过程,权限不能显式废除。只有在 tempdb 数据库中具有显式 CREATE PROCEDURE 权限的用户,才可以在该数据库中显式创建临时过程(不使用编号符命名)。可以授予或废除这些过程中的权限。
r@ aB|NW)g(r;i051Testing软件测试网LGK(vYv
3`6Y"RV6WB Qp0说明 频繁使用临时存储过程会在 tempdb 中的系统表上产生争用,从而对性能产生负面影响。建议使用 sp_executesql 代替。sp_executesql 不在系统表中存储数据,因此可以避免这一问题。51Testing软件测试网B`*P$y7CU
;h k5VMQ|Us,\?051Testing软件测试网9C)Fo-_#S\l
自动执行存储过程
l9b)x!mq0SQL Server 启动时可以自动执行一个或多个存储过程。这些存储过程必须由系统管理员创建,并在 sysadmin 固定服务器角色下作为后台过程执行。这些过程不能有任何输入参数。51Testing软件测试网X#`d*v(V9wS}%Q7P
对启动过程的数目没有限制,但是要注意,每个启动过程在执行时都会占用一个连接。如果必须在启动时执行多个过程,但不需要并行执行,则可以指定一个过程作为启动过程,让该过程调用其它过程。这样就只占用一个连接。
[BzHm051Testing软件测试网GSW] [在启动时恢复了最后一个数据库后,即开始执行存储过程。若要跳过这些存储过程的执行,请将启动参数指定为跟踪标记 4022。如果以最低配置启动 SQL Server(使用 -f 标记),则启动存储过程也不会执行。有关更多信息,请参见跟踪标记。
ZP0Yp+U:c*W051Testing软件测试网K;c$["ve&`(n wT若要创建启动存储过程,必须作为 sysadmin 固定服务器角色的成员登录,并在 master 数据库中创建存储过程。
2y ~0?'\3uImYfK&D051Testing软件测试网U,R/p\L6a使用 sp_procoption 可以:
#q_,C hT|vW4R@ |0HS^M:b/H0将现有存储过程指定为启动过程。51Testing软件测试网ZH,L"Z:o
F![*HG%F!F p kf_0停止在 SQL Server 启动时执行过程。
p'Ug]6B5T$LI*I^051Testing软件测试网#X bJW$w R%H ~1Z]c$E(pt3K%R6x051Testing软件测试网URG*M"}-i51Testing软件测试网
m;gd$`N:N.LbG
查看 SQL Server 启动时执行的所有过程的列表。51Testing软件测试网W4d$M,tP+R/YI
存储过程嵌套
hhMni^0存储过程可以嵌套,即一个存储过程可以调用另一个存储过程。在被调用过程开始执行时,嵌套级将增加,在被调用过程执行结束后,嵌套级将减少。如果超出最大的嵌套级,会使整个调用过程链失败。可用 @@NESTLEVEL 函数返回当前的嵌套级。51Testing软件测试网3w5s#F9\9cs|a7j
若要估计编译后的存储过程大小,请使用下列性能监视计数器。
B6}8~CPe4d6zij`051Testing软件测试网 ta-KdQ0AZ H性能监视器对象名 性能监视计数器名称51Testing软件测试网'jSeg
_
SQLServer:缓冲区管理器 高速缓存大小(页面数)51Testing软件测试网U/K+_d/{|/T)z\
SQLServer:高速缓存管理器 高速缓存命中率
#Y&Oi2U/t(x"r+uB4Z0高速缓存页
T1`Qw }#M]9Q0高速缓存对象计数*
vs2|Nd!Ge7D aj a0* 各种分类的高速缓存对象均可以使用这些计数器,包括特殊 sql、准备 sql、过程、触发器等。51Testing软件测试网~'fpWs
;c/Q%G A2`Sfq _0有关更多信息,请参见 SQL Server:Buffer Manager 对象和 SQL Server:Cache Manager 对象。51Testing软件测试网!k"e8cEK
4d,]T[u0sql_statement 限制
| }%sA$E1]I0除了 SET SHOWPLAN_TEXT 和 SET SHOWPLAN_ALL 之外(这两个语句必须是批处理中仅有的语句),任何 SET 语句均可以在存储过程内部指定。所选择的 SET 选项在存储过程执行过程中有效,之后恢复为原来的设置。
BB2P [M)t2?0如果其他用户要使用某个存储过程,那么在该存储过程内部,一些语句使用的对象名必须使用对象所有者的名称限定。这些语句包括:
"bAg'qXi051Testing软件测试网P4FL g&IrALTER TABLE51Testing软件测试网V7EdTV out
51Testing软件测试网2^#e)L%a1l2@P7i
c
N`"v8H0CREATE INDEX
LR:z%\%V:P
PpMy051Testing软件测试网'V;Xf5| H%M-ET!D`
CREATE TABLE51Testing软件测试网n;s#tR
OqDq6f7C
51Testing软件测试网$_k^E7Q.mv%P
所有 DBCC 语句51Testing软件测试网!XZ3uV}
s
]/k
"P,[+vH(M7X)X5`0DROP TABLE51Testing软件测试网*Xc1XS#e/^
w9e6D;JTQ0DROP INDEX51Testing软件测试网%GfBz"G9x
kN.gKM
yB0TRUNCATE TABLE
@2j3si&WI6nJ0
V(sS5R"yU7I0UPDATE STATISTICS51Testing软件测试网\4Pw)}k+eL
U
权限
2jSbA,~(w0C0CREATE PROCEDURE 的权限默认授予 sysadmin 固定服务器角色成员和 db_owner 和 db_ddladmin 固定数据库角色成员。sysadmin 固定服务器角色成员和 db_owner 固定数据库角色成员可以将 CREATE PROCEDURE 权限转让给其他用户。执行存储过程的权限授予过程的所有者,该所有者可以为其它数据库用户设置执行权限。51Testing软件测试网;G}mu5]eY
`oe-a"Yfr0示例
j;uo_)iM0A. 使用带有复杂 SELECT 语句的简单过程
Qjn'Rb6?0下面的存储过程从四个表的联接中返回所有作者(提供了姓名)、出版的书籍以及出版社。该存储过程不使用任何参数。51Testing软件测试网j
pLL(i&C+|
USE pubs51Testing软件测试网] o(Yr YB0Y$m
IF EXISTS (SELECT name FROM sysobjects
Gs B][d:~([n0 WHERE name = 'au_info_all' AND type = 'P')
i8@xMqH1ZG0 DROP PROCEDURE au_info_all
!v,Gm4_Es;pH4BU0GO
2i(pX+z
i0CREATE PROCEDURE au_info_all51Testing软件测试网&g5E#X%h yjN.p
AS51Testing软件测试网.FM'~sS
SELECT au_lname, au_fname, title, pub_name51Testing软件测试网~-E0? w)aQ c sz^
FROM authors a INNER JOIN titleauthor ta51Testing软件测试网`:{1P9Mg$lD+z)yU
ON a.au_id = ta.au_id INNER JOIN titles t
:]$R
C@B-ID#s0 ON t.title_id = ta.title_id INNER JOIN publishers p51Testing软件测试网 ~ Q*od5n1d?3M4q"G
ON t.pub_id = p.pub_id51Testing软件测试网#B9`M$vR$E#__)p@8^
GO
au_info_all 存储过程可以通过以下方法执行:
oDp a @:@0X@(a6\0f},_I8]V7C0EXECUTE au_info_all
GLI"bcNIu0-- Or51Testing软件测试网:u#di"q8I_+CNC0a
EXEC au_info_all51Testing软件测试网LB4Ui&y z
/S8Y@\EW0如果该过程是批处理中的第一条语句,则可使用:51Testing软件测试网m;]8Zj"aU2Wwi_d3_
51Testing软件测试网1G(I:GY;fB zau_info_all51Testing软件测试网9rQ!hW Z$jG"y
51Testing软件测试网0R^w|O;} U7uB. 使用带有参数的简单过程
.O3m`+Fjda5`:y0下面的存储过程从四个表的联接中只返回指定的作者(提供了姓名)、出版的书籍以及出版社。该存储过程接受与传递的参数精确匹配的值。51Testing软件测试网y
}~B*j8rw(En
O0B,h ZO)U0USE pubs51Testing软件测试网B)A&K3g0{@ ci$l
相关阅读:
- 教你快速掌握Oracle数据库结构的16个要点 (51testing, 2008-4-16)
- 快速掌握重启Oracle数据库的操作步骤 (51testing, 2008-4-17)
- 一种特别简单的MySQL数据库安装方法 (51testing, 2008-4-17)
- 实例讲解数据库备份过程中的常见问题 (51testing, 2008-4-21)
- 全面解析Oracle无法连接本地数据库问题 (51testing, 2008-4-22)
- 五种MySQL数据库可靠性方案的分析和比较 (51testing, 2008-4-22)
- SQL中IN,NOT IN,EXISTS,NOT EXISTS的用法和差别 (51testing, 2008-4-23)
- Oracle数据库导入导出方法的个人总结 (51testing, 2008-4-24)
- 存储过程语法知识1 (enjoyspace, 2008-4-28)
TAG: 数据库
标题搜索
日历
|
|||||||||
日 | 一 | 二 | 三 | 四 | 五 | 六 | |||
1 | 2 | 3 | 4 | 5 | 6 | ||||
7 | 8 | 9 | 10 | 11 | 12 | 13 | |||
14 | 15 | 16 | 17 | 18 | 19 | 20 | |||
21 | 22 | 23 | 24 | 25 | 26 | 27 | |||
28 | 29 | 30 |
我的存档
数据统计
- 访问量: 32425
- 日志数: 39
- 图片数: 2
- 建立时间: 2008-04-03
- 更新时间: 2012-02-03