sql server 2005擴(kuò)充技巧
實(shí)例:用SQLServer2005內(nèi)置工具建立審查系統(tǒng):能夠得到,如誰(shuí)訪問(wèn)了我們的數(shù)據(jù)、如何批準(zhǔn)訪問(wèn)權(quán)、以及我們?nèi)绾螌?duì)訪問(wèn)進(jìn)行監(jiān)控,以防止某些人入侵、登錄數(shù)據(jù)或做他們不該做的事情。引用這里
在SQL2005中處理交叉表: 關(guān)鍵字:PIVOT 和 UNPIVOT示例: DECLARE @t TABLE ([日期] datetime,[時(shí)間] varchar(20),[售貨金額] int)insert into @t select '2006-01-02','早上',50union all select '2006-01-02','中午',20union all select '2006-01-02','晚上',30union all select '2006-01-02','零晨',40union all select '2006-01-03','早上',40union all select '2006-01-03','中午',60union all select '2006-01-03','晚上',50union all select '2006-01-03','零晨',50union all select '2006-01-04','早上',80union all select '2006-01-04','中午',60union all select '2006-01-04','晚上',20union all select '2006-01-04','零晨',40--查詢select * ,金額小計(jì)=(select sum(售貨金額) from @t where 日期=PT.日期 ) from @t as TABPIVOT( max([售貨金額]) for [時(shí)間] in ([早上],[中午],[晚上],[零晨])) as PT--列不確定時(shí): DECLARE @S VARCHAR(MAX)SET @S=''SELECT @S=@S+',['+時(shí)間+']' FROM @t GROUP BY 時(shí)間SET @S=STUFF(@S,1,1,'')EXEC('select 日期,'+@S+',金額小計(jì)=(select sum(售貨金額) from @t where 日期=PT.日期 ) from @t as TABPIVOT( max(售貨金額) for 時(shí)間 in ('+@S+')) as PT')
SQL2005中拆分列值,借用XML,簡(jiǎn)單。見(jiàn)示例: -- 示例數(shù)據(jù)DECLARE @t TABLE(id int, [values] varchar(100))INSERT @t SELECT 1, 'aa,bb'UNION ALL SELECT 2, 'aaa,bbb,ccc'
-- 查詢處理SELECT A.id, B.valueFROM(SELECT id, [values] = CONVERT(xml,'<root><v>' + REPLACE([values], ',', '</v><v>') + '</v></root>')FROM @t)AOUTER APPLY(SELECT value = N.v.value('.', 'varchar(100)')FROM A.[values].nodes('/root/v') N(v))B 結(jié)果:1;aa1;bb2;aaa2;bbb2;ccc引用 :http://blog.csdn.net/itblog/archive/2006/06/05/774358.aspx
SQL2005中合并列值,見(jiàn)示例 -- 示例數(shù)據(jù)DECLARE @t TABLE(id int, value varchar(10))INSERT @t SELECT 1, 'aa'UNION ALL SELECT 1, 'bb'UNION ALL SELECT 2, 'aaa'UNION ALL SELECT 2, 'bbb'UNION ALL SELECT 2, 'ccc'
SELECT *FROM(SELECT DISTINCTidFROM @t)AOUTER APPLY(SELECT [values]= STUFF(REPLACE(REPLACE((SELECT value FROM @t NWHERE id = A.idFOR XML AUTO), '<N value='', ','), ''/>', ''), 1, 1, ''))N
/**//*--結(jié)果id; values----------- ----------------1aa,bb2aaa,bbb,ccc 更多見(jiàn):http://blog.csdn.net/itblog/archive/2006/06/05/774363.aspx
SQL2005新函數(shù),排列函數(shù):示例1: 在結(jié)果集中顯示行號(hào) ROW_NUMBER ( )函數(shù) 語(yǔ)法:ROW_NUMBER() OVER ( [ <partition_by_clause> ] <order_by_clause> )SELECT ROW_NUMBER() OVER (ORDER BY id) AS 行號(hào),* FROM sysobjects 返回結(jié)果集:行號(hào) 對(duì)象名稱; 1;;;sp_MSalreadyhavegeneration2;;;sp_MSwritemergeperfcounter3;;;TABLE_PRIVILEGES
在2000版本中要這樣實(shí)現(xiàn) SELECT Identity(int,1,1) AS Num,* INTO #temptable FROM TableName SELECT*FROM #temptableDROP TABLE #temptable 示例2:RANK()函數(shù)保留列表中行的位置序號(hào),對(duì)于每個(gè)重復(fù)值,這個(gè)函數(shù)跳過(guò)下面值,于是下一個(gè)不重復(fù)的值就保留在了正確的位置上了。DENSE_RANK()函數(shù)工作方式是相同的,不過(guò)它不跳過(guò)每個(gè)連帶之后的數(shù)字,這樣就不會(huì)有數(shù)字消失了,不過(guò)排列序號(hào)位置出現(xiàn)連帶的地方就丟失了。舉例(在做學(xué)生成績(jī)排名之類的時(shí)非常有作用。這兩個(gè)非常有用)
示例3:NTITLE(n)函數(shù),將結(jié)果切分為有限數(shù)量的排列組。更多示例見(jiàn)聯(lián)機(jī)叢書(shū).
sql 2005 express版本,需要加增加圖形管理器,下載,express版本中默認(rèn)沒(méi)有,sql2005 功能包 列表; sql2005導(dǎo)入導(dǎo)出向?qū)? C:Program FilesMicrosoft SQL Server90DTSBinnDTSWizard.exe 可自己在工具--外部工具中--添加引用.好比快捷方式。
