sql server 查詢結果集自動添加編號

發表于:2013-04-22來源:Csdn作者:起點ing點擊數: 標簽:SQL Server
SQL提供了一個IDENTITY Function,可以得到標識列的值,不過可惜的很的是,這個函數只能用于SELECT INTO語句,所以我們只好引入一個臨時表了 Ex: USE pubs SELECT IDENTITY(INT, 1, 1) AS Rank,au_lname,au_fname

  SQL提供了一個IDENTITY Function,可以得到標識列的值,不過可惜的很的是,這個函數只能用于SELECT INTO語句,所以我們只好引入一個臨時表了

  Ex:

  USE pubs

  SELECT IDENTITY(INT, 1, 1) AS Rank,au_lname,au_fname

  INTO #tmp

  FROM authors

  SELECT * FROM #tmp

  DROP TABLE #tmp

  這種方法的性能好,不過缺點是必須通過幾條SQL語句才能完成。

  所以如果可能的話,一般還是建議在客戶端完成這一操作.

  sqlserver2005以上版本可以借助分析函數實現。

  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

  通過表達式可免除你過去創建臨時表的麻煩。

  www.knowsky.com

  --例子:結合通用表達式進行分頁

  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

  特別,通過表達式還支持遞歸。

原文轉自:http://blog.csdn.net/zgyhh/article/details/8832987

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97