国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

sql server 2005擴充技巧

2024-08-31 00:51:52
字體:
來源:轉載
供稿:網友

實例:用SQLServer2005內置工具建立審查系統:能夠得到,如誰訪問了我們的數據、如何批準訪問權、以及我們如何對訪問進行監控,以防止某些人入侵、登錄數據或做他們不該做的事情。引用這里

在SQL2005中處理交叉表: 關鍵字:PIVOT 和 UNPIVOT
示例: DECLARE @t TABLE ([日期] datetime,[時間] varchar(20),[售貨金額] int)
insert into @t select '2006-01-02','早上',50
union all select '2006-01-02','中午',20
union all select '2006-01-02','晚上',30
union all select '2006-01-02','零晨',40
union all select '2006-01-03','早上',40
union all select '2006-01-03','中午',60
union all select '2006-01-03','晚上',50
union all select '2006-01-03','零晨',50
union all select '2006-01-04','早上',80
union all select '2006-01-04','中午',60
union all select '2006-01-04','晚上',20
union all select '2006-01-04','零晨',40
--查詢
select * ,金額小計=(select sum(售貨金額) from @t where 日期=PT.日期 ) from @t as TAB
PIVOT
( max([售貨金額])
  for [時間] in ([早上],[中午],[晚上],[零晨])
) as PT
 --列不確定時: DECLARE @S VARCHAR(MAX)
SET @S=''
SELECT @S=@S+',['+時間+']' FROM @t
  GROUP BY 時間
SET @S=STUFF(@S,1,1,'')
EXEC('
select 日期,'+@S+',金額小計=(select sum(售貨金額) from @t where 日期=PT.日期 ) from @t as TAB
PIVOT
( max(售貨金額)
  for 時間 in ('+@S+')
) as PT
')

SQL2005中拆分列值,借用xml,簡單。見示例: -- 示例數據
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.value
FROM(
SELECT id, [values] = CONVERT(xml,
'<root><v>' + REPLACE([values], ',', '</v><v>') + '</v></root>')
FROM @t
)A
OUTER APPLY(
SELECT value = N.v.value('.', 'varchar(100)')
FROM A.[values].nodes('/root/v') N(v)
)B 結果:
1    aa
1    bb
2    aaa
2    bbb
2    ccc
引用 :http://blog.csdn.net/itblog/archive/2006/06/05/774358.aspx

SQL2005中合并列值,見示例 -- 示例數據
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 DISTINCT
id
FROM @t
)A
OUTER APPLY(
SELECT [values]= STUFF(REPLACE(REPLACE(
(
SELECT value FROM @t N
WHERE id = A.id
FOR XML AUTO
), '<N value="', ','), '"/>', ''), 1, 1, '')
)N

/**//*--結果
id          values
----------- ----------------
1           aa,bb
2           aaa,bbb,ccc 更多見:http://blog.csdn.net/itblog/archive/2006/06/05/774363.aspx


SQL2005新函數,排列函數:
示例1: 在結果集中顯示行號 ROW_NUMBER ( )函數 語法:
ROW_NUMBER() OVER ( [ <partition_by_clause> ] <order_by_clause> )
SELECT ROW_NUMBER() OVER (ORDER BY id) AS 行號,* FROM sysobjects 返回結果集:
行號 對象名稱 
1      sp_MSalreadyhavegeneration
2      sp_MSwritemergeperfcounter  
3      TABLE_PRIVILEGES

在2000版本中要這樣實現 SELECT Identity(int,1,1) AS Num,* INTO #temptable FROM TableName
SELECT*FROM #temptable
DROP TABLE #temptable
示例2:RANK()函數保留列表中行的位置序號,對于每個重復值,這個函數跳過下面值,于是下一個不重復的值就保留在了正確的位置上了。
DENSE_RANK()函數工作方式是相同的,不過它不跳過每個連帶之后的數字,這樣就不會有數字消失了,不過排列序號位置出現連帶的地方就丟失了。
舉例(在做學生成績排名之類的時非常有作用。這兩個非常有用)

示例3:NTITLE(n)函數,將結果切分為有限數量的排列組。更多示例見聯機叢書.


sql 2005 express版本,需要加增加圖形管理器,下載,express版本中默認沒有,sql2005 功能包 列表 
sql2005導入導出向導: C:/Program Files/Microsoft SQL Server/90/DTS/Binn/DTSWizard.exe 可自己在工具--外部工具中--添加引用.好比快捷方式。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南和县| 秦安县| 昌江| 崇阳县| 陕西省| 怀安县| 阿巴嘎旗| 平陆县| 辽源市| 洪湖市| 东城区| 农安县| 尤溪县| 海城市| 北川| 静宁县| 镇平县| 股票| 深州市| 耒阳市| 孝义市| 武城县| 志丹县| 高安市| 石河子市| 大悟县| 安康市| 阿克| 新巴尔虎左旗| 襄城县| 隆回县| 合江县| 法库县| 靖江市| 成安县| 资阳市| 红桥区| 南昌县| 弋阳县| 若尔盖县| 奈曼旗|