所有人都知道select top 的用法,但很多人还不知道update top 和 delete top 怎么用。以往的做法是set rowcount来指定,其实SQL2005中对于Top语句的增强除了参数化之外还包括对update和delete的支持,但可惜的是还不支持自定义的order by列。如果要自定义派
所有人都知道select top 的用法,但很多人还不知道update top 和 delete top 怎么用。以往的做法是set rowcount来指定,其实SQL2005中对于Top语句的增强除了参数化之外还包括对update和delete的支持,但可惜的是还不支持自定义的order by列。如果要自定义派序列可以借助CTE.对于CTE的任何更改都会影响到原始表。
我们看下面的测试代码。
设置
没有计数
上
使用
临时数据库
走
如果
(object_id
('tb'
) 是
不是
空
)
掉落
桌子
待定
走
创建
桌子
待定
(id
int
身份
(1
,
1
),
名字
varchar
(10
),
标签
int
默认
0
)
插入
进入
待定
(姓名
) 选择
'a'
插入
进入
待定
(姓名
) 选择
'b'
插入
进入
待定
(姓名
) 选择
'c'
插入
进入
待定
(姓名
) 选择
'd'
插入
进入
待定
(姓名
) 选择
'e'
/*--更新前两行
id 名称 标签
------------ ---------- -----------
1 a 1
2 b 1
3 c 0
4 d 0
5 e 0
*/
更新
顶
(2
) 待定
设置
标签
=
1
选择
*
来自
待定
/*--更新后两行
id 名称 标签
------------ ---------- -----------
1 a 1
2 b 1
3 c 0
4 d 1
5 e 1
*/
;与
t
作为
(
选择
顶
(2
) *
来自
待定
下单
作者
id
描述
)
更新
t
设置
标签
=
1
选择
*
来自
待定
/*--删除前两行
id 名称 标签
------------ ---------- -----------
3 c 0
4 d 1
5 e 1
*/
删除
顶
(2
) 来自
待定
select
*
from
tb
/*--删除后两行
id name tag
----------- ---------- -----------
3 c 0
*/
;with
t
as
(
select
top
(2
) *
from
tb
order
by
id
desc
)
delete
from
t
select
*
from
tb
set
nocount
off
如果你感兴趣的话可以自己先思考一下,我给一个提示:
SQLServer2005有一个关键字Output,它可以将更改和插入的数据输出,我们配合update top就可以模拟出来一个相对高效的独占查询的事物。此功能适合用在并行的任务处理或者消费中。
如果你想不出来,请参考后面一篇文章,如果你写出来了,那也和我写的比较一下吧:p