设为首页
收藏本站
最新电影
> 子栏目 Asp | Jsp | XML | XSL | Div+Css | 自定义函数 | 数据库 | 脚本特效
您现在的位置: 首页=>后台技术=>数据库 订阅本栏目  
SQL Server 2005新功能概述(1) - TSQL
时间: 2008-12-27 23:56:54 阅读次数:3274


 

SQL Server 2005相对于SQL Server 2000改进很大,有些还是非常实用的飞!飞Asp技术乐园

举几个例子来简单说明 这些例子我引用了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

通过表达式可免除你过去创建临时表的麻烦飞@飞Asp技术乐园

 

--例子:结合通用表达式进行分页
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

特别,通过表达式还支持递归


6. 直接发布Web Service

想要把store procedure变成Web Service就用这个吧,.NET, IIS都不需要,通过Windows 2003的HTTP Protocol Stack直接发布WebService,用这个功能需要Windows 2003 sp1

--DataSet CustOrdersOrders(string customerID) 
CREATE ENDPOINT Orders_Endpoint 
state
=started 
as http( 
    path
='/sql/orders'
    AUTHENTICATION
=(INTEGRATED), 
    ports
=(clear) 

for soap( 
    WebMethod 
'CustOrdersOrders'(   
        name
='Northwind.dbo.CustOrdersOrders' 
    ), 
    
    wsdl
=default
    
database='Northwind'
    namespace
='http://mysite.org/' 
)



站内搜索    

下一篇Microsoft SQL Server 2005 Service Pack 3(sqlserver2005 sp3)微软官方下载地址

上一篇数据类型详解 MSSQL

本栏目最新 栏目最新列表
access由于您和其他用户试图同时改变同一数
Microsoft SQL Server 2005 Service Pack 3
MySQL时间戳转换的方法
清除,删除表中数据的方法
mysql常用时间函数用法解释
网站优化策划 栏目最新列表
增加网站外链的快速方法
网站上线前必做的30个检查
新的友情链接参考标准(没有google的PR情况
优化Google的AdSense广告的五个工具
王通讲SEO八大基础
站点最新 站点最新列表
微博推广的一些技巧
xhEditor v1.1.7 发布,
收集的一些轻量级非常实
50个新鲜兼容最新版本的
javascript中cookie的设
Excel中出现#VALUE!、#D
jquery插件:飞飞表情插件
十个使用HTML5开发的精彩
支持HTML5的浏览器有哪些
飞妮莫属:漫画:如何写出
历史最热10条信息  
MIME介绍 及 [1] [2] [3]
巧用Google和迅雷来下载
Transact SQL 常 [1] [2]
VIA Rhine II Fast Ethe
电脑常用端 [1] [2] [3]
Do you get a kick out
十道羊皮卷 欣赏+mp3版+
每日一句:A friend and
每日一句:Theres no tu
经典__悟透JavaScript
 width= 
伟哥博客 西安房产 123最新电影 三四六四