赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

SQL Server 2005改进后的几个实用新特性

发布时间:2008.05.07 04:47     来源:赛迪网    作者:Nick

【赛迪网-IT技术报道】SQL Server 2005相对于SQL Server 2000做了很大的改进,许些新特性是非常实用的。本文中将通过几个具体示例进行详细的说明。( 这些例子引用Northwind库)

1. TOP 表达式

SQL Server 2000的TOP是个固定值,是不是觉得差强人意,现在改进了。

--前n名的订单

declare @n int

set @n = 10

select TOP(@n) * from Orders

2. 分页

不知大家过去用SQL Server 2000是如何分页的,大多都用到了临时表。SQL Server 2005就支持分页,性能也非常不错。

--按Freight从小到大排序,求20到30行的结果

select * from(select OrderId, Freight, ROW_NUMBER() OVER(order by Freight) as row from Orders) a

where row between 20 and 30

3. 排名

select * from(select OrderId, Freight, RANK() OVER(order by Freight) as rank from Orders) a

where rank between 20 and 30

4. try ... catch

SQL Server 2000没有异常,T-SQL必须逐行检查错误代码,对于习惯了try catch程序员,2005是不是更加亲切:

SET XACT_ABORT ON -- 打开 try功能

BEGIN TRY

begin tran

insert into Orders(CustomerId) values(-1)

commit tran

print 'commited'

END TRY

BEGIN CATCH

rollback

print 'rolled back'

END CATCH

5. 通用表达式CTE

通过表达式可以免除你过去创建临时表的麻烦。

例:结合通用表达式进行分页

WITH OrderFreight AS(

select OrderId, Freight, ROW_NUMBER() OVER(order by Freight) as row from Orders

)

select OrderId, Freight from OrderFreight where row between 10 and 20

特别之处:通过表达式还可以支持递归。(责任编辑:卢兆林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· SQL Server 2005中实现自动备份 (05-05) · 在SQL Server 2005数据库中实现自动备份 (04-29)
· SQL Server 2005数据库IN运算的一个错误 (04-28) · 讲解SQL Server 2005数据库表的递归查询 (04-20)
· 深入讲解SQL Server 2005数据库中的SMO (04-20) · SQL Server 2005数据库中表的递归查询 (04-16)
· 在SQL Server 2005中用证书加密数据 (04-12) · 怎样在SQL Server 2005中用证书加密数据 (04-11)
· 不能安装SQL Server 2005的问题及解决方法 (04-11) · SQL Server 2005数据库镜像配置脚本示例 (04-11)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
· 北京工商局:网店办牌照8月1日肯定实施
· 工信部:全国移动电话用户已达6.01亿户
· 签合同前的四问 谈八大厂商“云计算”理念
· 亚略特烟草解决方案 移民安置信息管理系统
  IT博客 ·曾剑秋·项立刚·Java学习·网管
  IT技术论坛 ·开发·网管·安全·数据库·系统