SQLServer 2008中SQL增强之二 Top新用途


一、TOP替代Set RowCount
在SQL Server 2005之前的传统SQL语句中,top语句是不支持局部变量的。见
http://www.phpstudy.net/article/27089.htm
此时可以使用Set RowCount,但是在SQL Server 2005/2008中,TOP通常执行得更快,所以应该用TOP关键字来取代Set RowCount。

复制代码 代码如下:

/***************创建测试表*********************
****************downmoo 3w@live.cn ***************/
IF NOT OBJECT_ID('[Demo_Top]') IS NULL
DROP TABLE [Demo_Top]
GO
Create table [Demo_Top]
(PID int identity(1,1) primary key not null
,PName nvarchar(100) null
,AddTime dateTime null
,PGuid Nvarchar(40)
)
go
truncate table [Demo_Top]
/***************创建1002条测试数据*********************
****************downmoo 3w@live.cn ***************/
declare @d datetime
set @d=getdate()
declare @i int
set @i=1
while @i<=1002
begin
insert into [Demo_Top]
select cast(datepart(ms,getdate()) as nvarchar(3))+Replicate('A',datepart(ss,getdate()))
,getdate()
,NewID()
set @i=@i+1
end

--注意TOP关键字可以用于Select,Update和Delete语句中
复制代码 代码如下:

Declare @percentage float
set @percentage=1
select Top (@percentage) percent PName from [Demo_Top] order by PName
--注意是11行。(11 row(s) affected)

邀月注:如果只是需要一些样本,也可以使用TableSample,以下语句返回表Demo_Top的一定百分比的随机行
复制代码 代码如下:

select PName,AddTime, PGuid from [Demo_Top]
TableSample System(10 percent)
--(77 row(s) affected)

注意这个百分比是表数据页的百分比,而不是记录数的百分比,因此记录数目是不确定的。
二、TOP分块修改数据
TOP的第二个关键改进是支持数据的分块操作。换句话说,避免在一个语句中执行非常大的操作,而把修改分成多个小块,这大大改善了大数据量、大访问量的表的并发性,可以用于大的报表或数据仓库应用程序。此外,分块操作可以避免日志的快速增长,因为前一操作完成后,可能会重用日志空间。如果操作中有事务,已经完成的修改数据已经可以用于查询,而不必等待所有的修改完成。
仍以上表为例:
复制代码 代码如下:

while (select count(1) from [Demo_Top])>0
begin
delete top (202) from [Demo_Top]
end
/*
(202 row(s) affected)
(202 row(s) affected)
(202 row(s) affected)
(202 row(s) affected)
(194 row(s) affected)
*/

注意是每批删除202条数据,TOP也可以用于Select和Update语句,其中后者更为实用。
--Select TOP(100)
--Update TOP(100)
邀月注:本文版权由邀月和博客园共同所有,转载请注明出处。



相关阅读:
ASP.NET中实现中文简/繁体自动转换的类
Eclipse编程工具 在Ubuntu下的外观设置
GRUB不能启动解决全攻略
PHP+MYSQL网站开发中关于时间的问题
js实现兼容IE6与IE7的DIV高度
大家看了就明白了css样式中类class与标识id选择符的区别小结
CSS网页设计时关于字体大小的设计
PHP编实现程动态图像的创建代码
Exchange 2007 Direct Push Mail功能
WordPress优化(2):cacheAsFile静态网页
简单介绍Web Developer插件制作网页
将XP SP3集成到Windows XP安装光盘
Linux教程之Linux dir命令
IIS服务器排错
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 短小精干的情色短篇小说 爱情宣言经典语录2016 我哭了……400字 小学四年级作文350字:高科技之后…… 小学六年级作文600字:下着雨,向前走 全局干部进状态动员大会讲话 政务大厅建设在转变政府职能中的实践与探索 观六十周年国庆大典有感 趣味圣诞祝福语 美丽的达茂旗! 高中一年级寒假读书笔记5篇:《童年》 跌倒了,就爬起来作文 小学五年级作文1000字:小猴子和小狗熊的故事 这些话也许是你一生都在寻找的 送韦商州弼 小学五年级作文900字:老师生气了 猴子的红屁股作文1000字 演讲稿——我的环保节日作文1100字 高中入团申请书的范文(标准) 关于妈妈的爱作文600字 信息系统专业求职的自我介绍 面试的技巧有哪些?应当面试问题的方法 国庆蜗居在家 我家的植物作文100字 办事处工业三产业年度工作总结范文 卵石 爱与喜欢作文250字 清欢,一朵盛放在烟火里的欣喜 让多威,在祖国的大地上飘扬 一年级学困生转化工作计划 北大医院分娩镇痛学习感想 我的岳母 公安分局电厂派出所工作总结 学校党支部工作计划(2010年) 《雨之歌》教案 庄子:在我们无路可走的时候(转载) 鼓励人的励志语句 守护甜心之梦蝶樱兰8 漂流瓶作文450字 一个特别的老师 早晨励志语录 小学五年级作文350字:我打破了迷信 我喜欢的“马萨诸塞楼” 高一语文教学总结 2016新学期学生会工作计划 数科院优秀团干申请书 我最喜欢的历史人物——曹操作文700字 【来去里】 重阳节敬老祝福语 看图写话 让座 李欣悦

Copyright © 2016 phpStudy |