SQL Server 2005相对于SQL Server 2000改进很大,有些还是非常实用的。
举几个例子来简单说明 这些例子我引用了Northwind库。
1. TOP 表达式
SQL Server 2000的TOP是个固定值,是不是觉得不爽,现在改进了。
--前n名的订单
declare@nint
set@n=10
selectTOP(@n)*fromOrders
2. 分页
不知各位过去用SQL Server 2000是怎么分页的,大多都用到了临时表。SQL Server 2005一句话就支持分页,性能据说也非常不错。
--按Freight从小到大排序,求20到30行的结果
select*from(
selectOrderId,Freight,ROW_NUMBER()OVER(orderbyFreight)asrowfromOrders
)a
whererowbetween20and30
3. 排名
select*from(
selectOrderId,Freight,RANK()OVER(orderbyFreight)asrankfromOrders
)a
whererankbetween20and30
4. try ... catch
SQL Server 2000没有异常,T-SQL必须逐行检查错误代码,对于习惯了try catch程序员,2005是不是更加亲切:
SETXACT_ABORTON--打开try功能
BEGINTRY
begintran
insertintoOrders(CustomerId)values(-1)
committran
print'commited'
ENDTRY
BEGINCATCH
rollback
print'rolledback'
ENDCATCH
5. 通用表达式CTE
通过表达式可免除你过去创建临时表的麻烦。
--例子:结合通用表达式进行分页
WITHOrderFreightAS(
selectOrderId,Freight,ROW_NUMBER()OVER(orderbyFreight)asrowfromOrders
)
selectOrderId,FreightfromOrderFreightwhererowbetween10and20
特别,通过表达式还支持递归。
6. 直接发布Web Service
想要把store procedure变成Web Service就用这个吧,.NET, IIS都不需要,通过Windows 2003的HTTP Protocol Stack直接发布WebService,用这个功能需要Windows 2003 sp1
--DataSetCustOrdersOrders(stringcustomerID)
CREATEENDPOINTOrders_Endpoint
state=started
ashttp(
path='/sql/orders',
AUTHENTICATION=(INTEGRATED),
ports=(clear)
)
forsoap(
WebMethod'CustOrdersOrders'(
name='Northwind.dbo.CustOrdersOrders'
),
wsdl=default,
database='Northwind',
namespace='http://mysite.org/'
)
Web Service就发布好了,敲入http://localhost/sql/orders?wsdl得到wsdl
在http通讯时,例子代码使用的是Windows集成验证。
给个客户端例子。
privatevoidbutton1_Click(objectsender,EventArgse)
{
localhost.Orders_Endpointendp=newlocalhost.Orders_Endpoint();
endp.Credentials=System.Net.CredentialCache.DefaultCredentials;
object[]r=endp.CustOrdersOrders("VINET");
DataSetds=newDataSet();
foreach(objectoinr)
if(oisDataSet)ds=(DataSet)o;
dataGridView1.DataSource=ds.Tables[0];
}
SQL Server 2005支持basic, digest, sql auth等多种验证,你需要编写不同的验证代码。
分享到:
相关推荐
在当今的互联世界中,数据和管理数据的系统必须始终为用户可用且能够...SQL Server 2005 也包括了很多新的和改进的功能来帮助企业的IT团队更有效率的工作。SQL Server 2005 包括了几个在企业级数据管理中关键的增强:
SQL Server 2005新特性体验 SQL Server 2005新特性体验
SQL Server的升级之路系列课程(1):SQL Server 2005新特性及升级价值
此文档中详细的记载了,SQL Server 2005新特性之表分区的功能,希望可以帮下载的朋友们!
SQL Server的升级之路系列课程(11):利用SQL Server 2005新特性升级数据应用(上)
SQL Server的升级之路系列课程(12):利用SQL Server 2005新特性升级数据应用(下)
microsoft sql server 2012新特性(上、下),针对microsoft sql server 2012做了全面介绍,与大家分享。
Microsoft SQL Server 2005新特性。
SQL Server 2005版本特性介绍
该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解...
SQL Server 2008抢先看系列:SQL Server 2008 T-SQL新特性,介绍sql server 2008 的一些新的特性。
该书解释并比较了sql server 2000和sql server 2005在数据库开发相关问题上的解决方案,深入讨论了sql server 2005中新增的t-sql编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解...
作为《微软技术丛书》系列中的一本,本书全面、具体地介绍了SQL Server 2005的最新特性以及使用SQL Server 2005实现数据库解决方案所涉及的重要知识及经验。其中主要涉及了有关SQL Server 2005功能的基础知识,包括...
该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解...
sql server复习 ,基础知识由浅入深,根据教材总结,对学习sql server的朋友很好的帮助!