讓我們首先從coalesce具有文檔記錄的使用開始。根據MSDN,coalesce返回它的參數中第一個非空表達式。
例如,
SELECT COALESCE(NULL, NULL, NULL, GETDATE()) |
對Pivot(透視)使用Coalesce
如果你對AdventureWorks數據庫運行下面的語句:
SELECT Name FROM HumanResources.Department WHERE (GroupName = 'Executive General and Administration') |
圖1
如果你想透視數據,你可以運行下面的命令。
DECLARE @DepartmentName VARCHAR(1000) SELECT @DepartmentName = COALESCE(@DepartmentName,'') + Name + ';' FROM HumanResources.Department WHERE (GroupName = 'Executive General and Administration') SELECT @DepartmentName AS DepartmentNames |
圖2
使用Coalesce來執行多條SQL語句
如果你可以使用coalesce語句來透視數據,那么就可能通過透視數據和使用一個分號來分隔這些操作從而運行多條SQL語句。假設你想找到Person schema 中任何字段名稱為“Name”的字段的值。如果你執行下面的腳本它就起到這種作用。
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
下面是結果集。
圖3
我個人喜歡能夠使用三行代碼殺掉數據庫中的所有事務。如果你曾經試過恢復數據庫而不能獲得專門的訪問,你就知道這是多么有用的了。
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 |