SQL ServerCoalesce的大量使用的具体描述

数据库 SQL Server
我们今天主要描述的是SQL ServerCoalesce的大量使用(接合),假如你对其实际操作有不解之处的话,以下的文章那对你而言收获肯定不少。

我们今天是要和大家一起讨论的是SQL ServerCoalesce的大量使用(接合),首先我们是从SQL ServerCoalesce具有文档记录的具体操作开始的。根据MSDN,coalesce返回它的参数中第一个非空表达式。

例如,

  1. SELECT COALESCE(NULL, NULL, NULL, GETDATE())  

它将返回当前的日期。它略过第一个NULL值并返回第一个非空的值。

对Pivot(透视)使用Coalesce

如果你对AdventureWorks数据库运行下面的语句:

  1. SELECT Name   
  2. FROM HumanResources.Department  
  3. WHERE (GroupName = 'Executive General and Administration')  

你将获得像下面的一个标准结果集。

 

如果你想透视数据,你可以运行下面的命令。

  1. DECLARE @DepartmentName VARCHAR(1000)   
  2. SELECT @DepartmentName = COALESCE(@DepartmentName,'') + Name + ';'  
  3. FROM HumanResources.Department  
  4. WHERE (GroupName = 'Executive General and Administration')  
  5. SELECT @DepartmentName AS DepartmentNames  

并获得下面的结果集。

 

使用SQL ServerCoalesce来来执行多条SQL语句

如果你可以使用coalesce语句来透视数据,那么就可能通过透视数据和使用一个分号来分隔这些操作从而运行多条SQL语句。假设你想找到Person schema 中任何字段名称为“Name”的字段的值。如果你执行下面的脚本它就起到这种作用。
 

下面是结果集。

  1. DECLARE @SQL VARCHAR(MAX)   
  2. CREATE TABLE #TMP   
  3. (Clmn VARCHAR(500),   
  4. Val VARCHAR(50))   
  5. SELECT @SQL=COALESCE(@SQL,'')+CAST('INSERT INTO #TMP Select ''' + TABLE_SCHEMA + '.' + TABLE_NAME + '.'   
  6. + COLUMN_NAME + ''' AS Clmn, Name FROM ' + TABLE_SCHEMA + '.[' + TABLE_NAME +   
  7. '];' AS VARCHAR(MAX))   
  8. FROM INFORMATION_SCHEMA.COLUMNS   
  9. JOIN sysobjects B ON INFORMATION_SCHEMA.COLUMNS.TABLE_NAME = B.NAME   
  10. WHERE COLUMN_NAME = 'Name'   
  11. AND xtype = 'U'   
  12. AND TABLE_SCHEMA = 'Person'   
  13. PRINT @SQL   
  14. EXEC(@SQL)   
  15. SELECT * FROM #TMP   
  16. DROP TABLE #TMP   

我个人喜欢能够使用三行代码杀掉数据库中的所有事务。如果你曾经试过恢复数据库而不能获得专门的访问,你就知道这是多么有用的了。

  1. DECLARE @SQL VARCHAR(8000)   
  2. SELECT @SQL=COALESCE(@SQL,'')+'Kill '+CAST(spid AS VARCHAR(10))+ '; '  
  3. FROM sys.sysprocesses  
  4. WHERE DBID=DB_ID('AdventureWorks')  
  5. PRINT @SQL --EXEC(@SQL) Replace the print statement with exec to execute  

这将得出一个类似于下面的结果集。

 

以上的相关内容就是对SQL ServerCoalesce的介绍,望你能有所收获。

【编辑推荐】

  1. SQL Server2005插入汉字变问号的破解
  2. SQL Server拆分字符串的3常用种方法
  3. SQL Server 2005快照与查询的使用场景
  4. 破解SQL Server占内存过多很简单!
  5. SQL Server数据库Processor Affinity概述
责任编辑:佚名 来源: 赛迪网
相关推荐

2010-07-07 09:47:04

SQL Server索

2010-08-02 12:24:24

DB2 Resotre

2010-07-22 17:33:42

2010-07-16 15:42:32

SQL Server

2010-07-19 11:35:05

2010-07-05 11:01:37

Sql Server触

2010-07-20 13:52:27

SQL Server

2010-04-15 16:16:33

Oracle SQL

2010-05-26 13:50:15

MySQL备份

2010-06-17 15:09:49

SQL Server

2010-03-22 17:12:21

Python VIM

2010-03-19 08:47:10

Python源代码

2010-04-09 10:32:03

Oracle 数据库

2010-04-12 17:30:44

Oracle SQL调

2010-07-20 08:35:54

SQL Server锁

2010-06-28 13:56:16

SQL Server代

2010-07-07 09:27:15

SQL Server索

2010-07-19 18:04:23

SQL Server锁

2010-07-09 10:08:53

SQL Server函

2010-05-26 15:03:51

点赞
收藏

51CTO技术栈公众号