日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統 2688 0

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
特別,通過表達式還支持遞歸。

?

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


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 汶川县| 栖霞市| 高尔夫| 梨树县| 阿勒泰市| 凌源市| 韶山市| 德格县| 柘城县| 安陆市| 台州市| 西盟| 吴川市| 建德市| 德钦县| 牙克石市| 陆川县| 蛟河市| 翁源县| 镇原县| 成安县| 普宁市| 昌都县| 巴彦县| 荥阳市| 谢通门县| 屯留县| 建平县| 林甸县| 沭阳县| 杭锦旗| 辽宁省| 灵寿县| 类乌齐县| 板桥市| 武穴市| 五台县| 永寿县| 南乐县| 千阳县| 余姚市|