SQL ServerCoalesce的大量使用的具體描述
我們今天是要和大家一起討論的是SQL ServerCoalesce的大量使用(接合),首先我們是從SQL ServerCoalesce具有文檔記錄的具體操作開始的。根據(jù)MSDN,coalesce返回它的參數(shù)中第一個非空表達式。
例如,
- SELECT COALESCE(NULL, NULL, NULL, GETDATE())
 
它將返回當(dāng)前的日期。它略過第一個NULL值并返回第一個非空的值。
對Pivot(透視)使用Coalesce
如果你對AdventureWorks數(shù)據(jù)庫運行下面的語句:
- SELECT Name
 - FROM HumanResources.Department
 - WHERE (GroupName = 'Executive General and Administration')
 
你將獲得像下面的一個標準結(jié)果集。
如果你想透視數(shù)據(jù),你可以運行下面的命令。
- DECLARE @DepartmentName VARCHAR(1000)
 - SELECT @DepartmentName = COALESCE(@DepartmentName,'') + Name + ';'
 - FROM HumanResources.Department
 - WHERE (GroupName = 'Executive General and Administration')
 - SELECT @DepartmentName AS DepartmentNames
 
并獲得下面的結(jié)果集。
使用SQL ServerCoalesce來來執(zhí)行多條SQL語句
如果你可以使用coalesce語句來透視數(shù)據(jù),那么就可能通過透視數(shù)據(jù)和使用一個分號來分隔這些操作從而運行多條SQL語句。假設(shè)你想找到Person schema 中任何字段名稱為“Name”的字段的值。如果你執(zhí)行下面的腳本它就起到這種作用。
 
下面是結(jié)果集。
- DECLARE @SQL VARCHAR(MAX)
 - CREATE TABLE #TMP
 - (Clmn VARCHAR(500),
 - Val VARCHAR(50))
 - SELECT @SQL=COALESCE(@SQL,'')+CAST('INSERT INTO #TMP Select ''' + TABLE_SCHEMA + '.' + TABLE_NAME + '.'
 - + COLUMN_NAME + ''' AS Clmn, Name FROM ' + TABLE_SCHEMA + '.[' + TABLE_NAME +
 - '];' AS VARCHAR(MAX))
 - FROM INFORMATION_SCHEMA.COLUMNS
 - JOIN sysobjects B ON INFORMATION_SCHEMA.COLUMNS.TABLE_NAME = B.NAME
 - WHERE COLUMN_NAME = 'Name'
 - AND xtype = 'U'
 - AND TABLE_SCHEMA = 'Person'
 - PRINT @SQL
 - EXEC(@SQL)
 - SELECT * FROM #TMP
 - DROP TABLE #TMP
 
我個人喜歡能夠使用三行代碼殺掉數(shù)據(jù)庫中的所有事務(wù)。如果你曾經(jīng)試過恢復(fù)數(shù)據(jù)庫而不能獲得專門的訪問,你就知道這是多么有用的了。
- DECLARE @SQL VARCHAR(8000)
 - SELECT @SQL=COALESCE(@SQL,'')+'Kill '+CAST(spid AS VARCHAR(10))+ '; '
 - FROM sys.sysprocesses
 - WHERE DBID=DB_ID('AdventureWorks')
 - PRINT @SQL --EXEC(@SQL) Replace the print statement with exec to execute
 
這將得出一個類似于下面的結(jié)果集。
以上的相關(guān)內(nèi)容就是對SQL ServerCoalesce的介紹,望你能有所收獲。
【編輯推薦】















 
 
 
 
 
 
 