SQLServer2005的Top功能
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQLServer2005的Top功能,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2048字,纯文字阅读大概需要3分钟。
内容图文
![SQLServer2005的Top功能](/upload/InfoBanner/zyjiaocheng/564/e6112cc1b5b840e59bb78f79221cb374.jpg)
所有人都知道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的任何更改都会影响到原始表。
我们看下面的测试代码。
set
nocount
on
use
tempdb
go
if
(object_id
('tb'
) is
not
null
)
drop
table
tb
go
create
table
tb
(id
int
identity
(1
,
1
),
name
varchar
(10
),
tag
int
default
0
)
insert
into
tb
(name
) select
'a'
insert
into
tb
(name
) select
'b'
insert
into
tb
(name
) select
'c'
insert
into
tb
(name
) select
'd'
insert
into
tb
(name
) select
'e'
/*--更新前两行
id name tag
----------- ---------- -----------
1 a 1
2 b 1
3 c 0
4 d 0
5 e 0
*/
update
top
(2
) tb
set
tag
=
1
select
*
from
tb
/*--更新后两行
id name tag
----------- ---------- -----------
1 a 1
2 b 1
3 c 0
4 d 1
5 e 1
*/
;with
t
as
(
select
top
(2
) *
from
tb
order
by
id
desc
)
update
t
set
tag
=
1
select
*
from
tb
/*--删除前两行
id name tag
----------- ---------- -----------
3 c 0
4 d 1
5 e 1
*/
delete
top
(2
) from
tb
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
内容总结
以上是互联网集市为您收集整理的SQLServer2005的Top功能全部内容,希望文章能够帮你解决SQLServer2005的Top功能所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。