注释:任何时候,会话中只有一个表的 identity_insert 属性可以设置为 on。如果某个表已将此属性设置为 on,并且为另一个表发出了 set identity_insert on 语句,则 microsoft? sql server? 返回一个错误信息,指出 set identity_insert 已设置为 on 并报告此属性已设置为 on 的表。 如果插入值大于表的当前标识值,则 sql server 自动将新插入值作为当前标识值使用。 set identity_insert 的设置是在执行或运行时设置,而不是在分析时设置。
示例:下例创建一个含有标识列的表,并显示如何使用 set identity_insert 设置填充由 delete 语句导致的标识值中的空隙。
-- create products table. create table products (id int identity primary key, product varchar(40)) go -- inserting values into products table. insert into products (product) values (screwdriver) insert into products (product) values (hammer) insert into products (product) values (saw) insert into products (product) values (shovel) go
-- create a gap in the identity values. delete products where product = saw go
select * from products go
-- attempt to insert an explicit id value of 3; -- should return a warning. insert into products (id, product) values(3, garden shovel) go
-- set identity_insert to on. set identity_insert products on go
-- attempt to insert an explicit id value of 3 insert into products (id, product) values(3, garden shovel) go
select * from products go
-- drop products table. drop table products go
5. set implicit_transactions
说明:为连接设置隐性事务模式。
语法:set implicit_transactions { on | off }
注释:当设置为 on 时,set implicit_transactions 将连接设置为隐性事务模式。当设置为 off 时,则使连接返回到自动提交事务模式。 当连接是隐性事务模式且当前不在事务中时,执行下列语句将启动事务:
alter table fetch revoke create grant select delete insert truncate table drop open update
如果连接已经在打开的事务中,则上述语句不启动新事务。 对于因为该设置为 on 而自动打开的事务,用户必须在该事务结束时将其显式提交或回滚。否则当用户断开连接时,事务及其所包含的所有数据更改将回滚。在事务提交后,执行上述任一语句即可启动新事务。 隐性事务模式将保持有效,直到连接执行 set implicit_transactions off 语句使连接返回到自动提交模式。在自动提交模式下,如果各个语句成功完成则提交。 在进行连接时,sql server odbc 驱动程序和用于 sql server 的 microsoft ole db 提供程序自动将 implicit_transactions 设置为 off。对来自 db-library 应用程序的连接,set implicit_transactions 默认为 off。 当 set ansi_defaults 为 on 时,将启用 set implicit_transactions。 set implicit_transactions 的设置是在执行或运行时设置,而不是在分析时设置。
示例:下例演示在将 implicit_transactions 设置为 on 时显式或隐式启动事务。它使用 @@trancount 函数演示打开的事务和关闭的事务。
use pubs go
create table t1 (a int) go insert into t1 values (1) go
print use explicit transaction begin tran insert into t1 values (2) select tran count in transaction= @@trancount commit tran select tran count outside transaction= @@trancount go
print setting implicit_transactions on go set implicit_transactions on go
print use implicit transactions go -- no begin tran needed here. insert into t1 values (4) select tran count in transaction= @@trancount commit tran select tran count outside transaction= @@trancount go
print use explicit transactions with implicit_transactions on go begin tran insert into t1 values (5) select tran count in transaction= @@trancount commit tran select tran count outside transaction= @@trancount go
select * from t1 go
-- need to commit this tran too! drop table t1 commit tran go
6. set nocount 说明:使返回的结果中不包含有关受 transact-sql 语句影响的行数的信息。
语法:set nocount { on | off }
注释:当 set nocount 为 on 时,不返回计数(表示受 transact-sql 语句影响的行数)。当 set nocount 为 off 时,返回计数。 即使当 set nocount 为 on 时,也更新 @@rowcount 函数。 当 set nocount 为 on 时,将不给客户端发送存储过程中的每个语句的 done_in_proc 信息。当使用 microsoft? sql server? 提供的实用工具执行查询时,在 transact-sql 语句(如 select、insert、update 和 delete)结束时将不会在查询结果中显示"nn rows affected"。 如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。 set nocount 设置是在执行或运行时设置,而不是在分析时设置。
权限:set nocount 权限默认授予所有用户。
示例:下例在 osql 实用工具或 sql server 查询分析器中执行时,可防止显示有关受影响的行数的信息。
use pubs go -- display the count message. select au_lname from authors go use pubs go -- set nocount to on and no longer display the count message. set nocount on go select au_lname from authors go -- reset set nocount to off. set nocount off go
7. @@rowcount 说明:返回受上一语句影响的行数。
语法:@@rowcount
返回类型:integer
注释:任何不返回行的语句将这一变量设置为 0 ,如 if 语句。
示例:下面的示例执行 update 语句并用 @@rowcount 来检测是否有发生更改的行。
update authors set au_lname = jones where au_id = 999-888-7777 if @@rowcount = 0 print warning: no rows were updated
8. set rowcount
说明:使 microsoft? sql server? 在返回指定的行数之后停止处理查询。
语法:set rowcount { number | @number_var }
参数:number | @number_var 是在停止给定查询之前要处理的行数(整数)。
注释:建议将当前使用 set rowcount 的 delete、insert 和 update 语句重新编写为使用 top 语法。有关更多信息,请参见 delete、insert 或 update。 对于在远程表和本地及远程分区视图上执行的 insert、update 和 delete 语句,忽略 set rowcount 选项设置。 若要关闭该选项(以便返回所有的行),请将 set rowcount 指定为 0。 说明 设置 set rowcount 选项将使大多数 transact-sql 语句在已受指定数目的行影响后停止处理。这包括触发器和 insert、update 及 delete 等数据修改语句。rowcount 选项对动态游标无效,但限制键集的行集和不感知游标。使用该选项时应谨慎,它主要与 select 语句一起使用。 如果行数的值较小,则 set rowcount 替代 select 语句 top 关键字。 set rowcount 的设置是在执行或运行时设置,而不是在分析时设置。
权限:set rowcount 权限默认授予所有用户。
示例:set rowcount 在指定的行数后停止处理。在下例中,注意有 x 行满足预付款少于或等于 $5,000 的条件;但是,从更新所返回的行数中可以看出并非所有的行都得到处理。rowcount 影响所有的 transact-sql 语句。
use pubs go select count(*) as cnt from titles where advance >= 5000 go
下面是结果集:
cnt ----------- 11
(1 row(s) affected)
现在,将 rowcount 设置为 4,并更新预付款等于或大于 $5,000 的所有行。
-- set rowcount to 4. set rowcount 4 go update titles set advance = 5000 where advance >= 5000 go
注释:当 set xact_abort 为 on 时,如果 transact-sql 语句产生运行时错误,整个事务将终止并回滚。为 off 时,只回滚产生错误的 transact-sql 语句,而事务将继续进行处理。编译错误(如语法错误)不受 set xact_abort 的影响。 对于大多数 ole db 提供程序(包括 sql server),隐性或显式事务中的数据修改语句必须将 xact_abort 设置为 on。唯一不需要该选项的情况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询和分布式事务。 set xact_abort 的设置是在执行或运行时设置,而不是在分析时设置。
create table t1 (a int primary key) create table t2 (a int references t1(a)) go insert into t1 values (1) insert into t1 values (3) insert into t1 values (4) insert into t1 values (6) go set xact_abort off go begin tran insert into t2 values (1) insert into t2 values (2) /* foreign key error */ insert into t2 values (3) commit tran go
set xact_abort on go
begin tran insert into t2 values (4) insert into t2 values (5) /* foreign key error */ insert into t2 values (6) commit tran go
/* select shows only keys 1 and 3 added. key 2 insert failed and was rolled back, but xact_abort was off and rest of transaction succeeded. key 5 insert error with xact_abort on caused all of the second transaction to roll back. */