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

--sql2005之间噢能够可以使用下面的写法,但估计没人这样使用

--select top(15/3) 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

  • Rank() over()----------结果:1,1,3格式
  • Dense_Rank() over()----结果:1,1,2,2格式
  • Row_Number() over()----结果:1,2,3,4
  • Ntile(3) over()--------结果:按3等进行划分

4. try ... catch

SET XACT_ABORT ON  -- 打开 try功能  
BEGIN TRY  
    begin tran  
        )  
    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  
)  

特别,通用表表达式还支持递归。SQL Server CET 通用表表达式 之 精典递归

6.OUTPUT关键字

--定义一个表级变量,所有字段(包括自增长字段)都要定义
declare @InsertDetails Table
(
 CustomerID int,
 CustomerName nvarchar(50)
)
insert into customer output inserted.CustomerID ,inserted.CustomerName into
@Insertdetails
values('This is a test of putput keyword.')
select * from @insertdetails

--封装成存储过程

alert proc tt
(
 @customerID nvarchar(50)
)
as 
begin
 declare @InsertDetails Table
 (
  CustomerID int,
  CustomerName nvarchar(50)
 )

insert into customer output inserted.CustomerID ,inserted.CustomerName into
 @Insertdetails
 values(@customerID)
select * from @insertdetails
end

--调用存储过程:
tt 'Hello everyone'

7. 直接发布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/'  
)

Web Service就发布好了,敲入http://localhost/sql/orders?wsdl得到wsdl

待续...

SQL Server 2005的几个新功能的更多相关文章

  1. 修改SQL Server 2005 数据库文件名字

    对于SQLServer 2005的数据库文件名字的修改.不多说,见图: 对于数据库名的更改直接选中要修改的数据库,F2,你懂的,不懂的可以去屎了.....0.0 下面要修改数据库的文件名 原理就是利用 ...

  2. SQL Server 2005 版本的操作系统兼容性详细列表

    操作系统要求(32 位) 此表显示对于每种 32 位版本的 SQL Server 2005,操作系统是否可以运行其服务器软件. 有关如何在 Windows Server 2008 上安装 SQL Se ...

  3. SQL Server 2005中的CHECKSUM功能

    原文:SQL Server 2005中的CHECKSUM功能 转自此处 页面 checksum 是SQL2005的新功能,提供了一种比残缺页检测强大的机制检测IO方面的损坏.以下是详细描述: 页面 C ...

  4. 使用SQL Server 2005 新的语法ROW_NUMBER()进行分页的两种不同方式的性能比较

    相比在SQL Server 2000 中使用的分页方式,在SQL Server 2005中使用新的语法ROW_NUMBER()来分页效率要高出很多,但是很多人在使用ROW_NUMBER()这种分页方式 ...

  5. SQL SERVER 2005/2008 中关于架构的理解(二)

    本文上接SQL SERVER 2005/2008 中关于架构的理解(一)      架构的作用与示例 用户与架构(schema)分开,让数据库内各对象不再绑在某个用户账号上,可以解决SQL SERVE ...

  6. SQL Server 2005 Service Broker

    一.引言 SQL Server 2005 的一个主要成就是可以实现可靠.可扩展且功能完善的数据库应用程序.与 .NET Framework 2.0 公共语言运行库 (CLR) 的集成使开发人员可以将重 ...

  7. Access数据库导入到SQL Server 2005 Express中

    安装好SQL Server 2005 Express后,再安装SQL Server Management Studio Express CTP就可以很方便的使用控制台进行数据库的管理.但SQL Ser ...

  8. SQL SERVER 2005快捷键+visual studio 2008 快捷键

    一.SQL SERVER 2005快捷键  快捷键                                       功能           CTRL       +       SHIF ...

  9. SQL Server 2005的XML数据修改语言(XML DML)

    转:http://www.microsoft.com/china/msdn/library/data/sqlserver/XMLDML.mspx?mfr=true 作为对XQuery语言的扩展,XML ...

随机推荐

  1. 14、OpenCV实现图像的空间滤波——图像锐化及边缘检测

    1.图像锐化理论基础 1.锐化的概念 图像锐化的目的是使模糊的图像变得清晰起来,主要用于增强图像的灰度跳变部分,这一点与图像平滑对灰度跳变的抑制正好相反.而且从算子可以看出来,平滑是基于对图像领域的加 ...

  2. idm技术下载百度网盘

    原使用教程:https://www.haorenka.org/idm.html 使用idm下载器后实际下载速度,比原网盘客户端快很多 相关软件下载 参考上面的参考教程,这里只提供对应所需要的文件,有的 ...

  3. LeetCode 581. 最短无序连续子数组(Shortest Unsorted Continuous Subarray)

    581. 最短无序连续子数组 581. Shortest Unsorted Continuous Subarray 题目描述 给定一个整型数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序 ...

  4. [转帖]EPOLL和IOCP比较

    EPOLL和IOCP比较 https://blog.csdn.net/educast/article/details/15503179 IOCP 异步非阻塞EPOLL 异步阻塞   EPOLL是半成品 ...

  5. ubuntu下安装amqp扩展

    目录 环境 下载扩展: 安装amqp: 验证 环境 系统 ubuntu 16.04 php 7.1 下载扩展: sudo apt-get -y install gcc make autoconf li ...

  6. Linux基础-08-进程控制

    1. 系统监视和进程控制工具—top和free 1) top命令的功能:top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器. 2) ...

  7. dotnet Core学习之旅(序)

    .NET Core 新玩具,新工具,新生产力 我将在博客园我从0.1开始探索.NET Core 的过程. 为什么是从0.1开始而不是从0开始 我在微软刚宣布开源的时候便接触到了.NET Core 1. ...

  8. Map、Set的基本概括

    Map: 在运用map和set 集合之前首先要弄清楚它们的基本定义是什么. 简介:map是一种关联式容器,但是她储存方式是以键值对(key/value)存在的. Map用法: 定义Map集合并往集合中 ...

  9. QT-入门:创建项目时遇到工程工具集(Kit)找不到问题

    创建项目遇到了以下提示: Please add a kit in the options or via the maintenance tool of the SDK 解决方法: 在指定的工具链中设置 ...

  10. em...刚打完一点cf。。 有点子感悟

    首先,下笔一定要读清楚题目. 情况多考虑一下. 这几次的模拟赛,分类思想很重要,往往一大坨东西扔给你,你不去尝试分类的话就很难整理清楚.