實例:用SQLServer2005內(nèi)置工具建立審查系統(tǒng):能夠得到,如誰訪問了我們的數(shù)據(jù)、如何批準(zhǔn)訪

字號:

實例:用SQLServer2005內(nèi)置工具建立審查系統(tǒng):能夠得到,如誰訪問了我們的數(shù)據(jù)、如何批準(zhǔn)訪問權(quán)、以及我們?nèi)绾螌υL問進行監(jiān)控,以防止某些人入侵、登錄數(shù)據(jù)或做他們不該做的事情。引用這里
    在SQL2005中處理交叉表: 關(guān)鍵字: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,簡單。見示例: -- 示例數(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.value
    FROM(
    SELECT id, [values] = CONVERT(xml,
    '' + REPLACE([values], ',', '') + '')
    FROM @t
    )A
    OUTER APPLY(
    SELECT value = N.v.value('.', 'varchar(100)')
    FROM A.[values].nodes('/root/v') N(v)
    )B 結(jié)果:
    1 aa
    1 bb
    2 aaa
    2 bbb
    2 ccc
    引用 :http://blog.csdn.net/itblog/archive/2006/06/05/774358.aspx
    SQL2005中合并列值,見示例 -- 示例數(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 DISTINCT
    id
    FROM @t
    )A
    OUTER APPLY(
    SELECT [values]= STUFF(REPLACE(REPLACE(
    (
    SELECT value FROM @t N
    WHERE id = A.id
    FOR XML AUTO
    ), '', ''), 1, 1, '')
    )N
    /**//*--結(jié)果
    id values
    ----------- ----------------
    1 aa,bb
    2 aaa,bbb,ccc 更多見:http://blog.csdn.net/itblog/archive/2006/06/05/774363.aspx
    SQL2005新函數(shù),排列函數(shù):
    示例1: 在結(jié)果集中顯示行號 ROW_NUMBER ( )函數(shù) 語法:
    ROW_NUMBER() OVER ( [ ] )
    SELECT ROW_NUMBER() OVER (ORDER BY id) AS 行號,* FROM sysobjects 返回結(jié)果集:
    行號 對象名稱
    1 sp_MSalreadyhavegeneration
    2 sp_MSwritemergeperfcounter
    3 TABLE_PRIVILEGES
    在2000版本中要這樣實現(xiàn) SELECT Identity(int,1,1) AS Num,* INTO #temptable FROM TableName
    SELECT*FROM #temptable
    DROP TABLE #temptable
    示例2:RANK()函數(shù)保留列表中行的位置序號,對于每個重復(fù)值,這個函數(shù)跳過下面值,于是下一個不重復(fù)的值就保留在了正確的位置上了。
    DENSE_RANK()函數(shù)工作方式是相同的,不過它不跳過每個連帶之后的數(shù)字,這樣就不會有數(shù)字消失了,不過排列序號位置出現(xiàn)連帶的地方就丟失了。
    舉例(在做學(xué)生成績排名之類的時非常有作用。這兩個非常有用)
    示例3:NTITLE(n)函數(shù),將結(jié)果切分為有限數(shù)量的排列組。更多示例見聯(lián)機叢書.
    sql 2005 express版本,需要加增加圖形管理器,下載,express版本中默認(rèn)沒有,sql2005 功能包 列表
    sql2005導(dǎo)入導(dǎo)出向?qū)? C:\Program Files\Microsoft SQL Server\90\DTS\Binn\DTSWizard.exe 可自己在工具--外部工具中--添加引用.好比快捷方式。