巧用SQL語句,小技巧解決大問題!
朋友們,我們在寫SQL腳本的時候,可能一些看起來不起眼的小問題、卻讓我們非常頭疼。比如我們要寫一個備份數(shù)據(jù)庫的腳本,如果我們對服務器的硬盤分區(qū)和使用情況很了解,備份當然沒有問題,但如果我們不知道服務器硬盤如何分區(qū)、每個分區(qū)還有多少空間可用的情況下,您寫的備份語句可能就不好執(zhí)行了。
下面,我就日常我們可能會碰到的一些“大問題”,通過簡單的SQL腳本進行實現(xiàn)。
查看硬盤分區(qū)與可用空間
這個通過調(diào)用master數(shù)據(jù)庫下面的存儲過程xp_fixeddrives很容易實現(xiàn)。
EXEC master..xp_fixeddrives
獲取數(shù)據(jù)庫服務器的磁盤分區(qū)和可用空間
按照姓氏筆畫排序
這問題看起來很簡單,做起來可能會讓您毫無頭緒,通過調(diào)用MSSQL的字符集信息很容易實現(xiàn)。
- Select * From 表名 Order By 字段 Collate Chinese_PRC_Stroke_ci_as
按照姓氏筆畫排序
比較兩個表是否相等
這個看似簡單的問題,通常的寫法可能要些一大坨SQL進行各種對比,下面的方法就很簡單。
- if (select checksum_agg(binary_checksum(*)) from 表1) =(select checksum_agg(binary_checksum(*)) from 表2)
- print '相等'
- else
- print '不相等'
比較兩個表是否相等
分頁及獲取某個區(qū)間的數(shù)據(jù)記錄
如果獲取前多少條,大家都知道通過top n,如果數(shù)據(jù)本來有1000條,您想按照某種排序后,獲取其中的第10到11條該如何處理呢?SQL中提供了一個很好用的ROW_NUMBER()函數(shù),返回的就是行標,靈活運用您就會驚喜不斷。其語法格式如下:
- ROW_NUMBER() OVER ([ partition_by_clause ] order_by_clause)
其中:
- partition_by_clause:將FROM子句生成的結果集劃入應用了ROW_NUMBER()函數(shù)的分區(qū)??梢岳斫鉃?strong>分組。
- order_by_clause:確定將ROW_NUMBER值分配給分區(qū)中的行的順序。其實就是排序。
了解了這個,我們就可以寫了:
- select v.* from (
- select ROW_NUMBER() over(order by 排序字段) as FRowID,* from 表名
- ) as v
- where v.FRowID between 序列1 and 序列2
巧用ROW_NUMBER截取記錄
如果您不希望排序,只需要截取默認順序的記錄,可以這樣寫:
- select * from (
- select ROW_NUMBER() over(order by (select 0)) as FRowID,* from 表名
- ) as v
- where v.FRowID between 序列1 and 序列2
巧用ROW_NUMBER截取記錄
有關分組的,這里就不再贅述了。
查看與某一個表相關的視圖、存儲過程、函數(shù)
這也是一個看起來簡單做起來頭疼的問題。其實活用sysobjects和syscomments即可。
- select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'
查看引用表的所有視圖、存儲過程和函數(shù)
還有很多的小技巧,以后我們慢慢發(fā)掘吧。
【編輯推薦】