我们今天是要和大家一起讨论的是SQL ServerCoalesce的大量使用(接合),首先我们是从SQL ServerCoalesce具有文档记录的具体操作开始的。根据MSDN,coalesce返回它的参数中第一个非空表达式。
康县网站制作公司哪家好,找创新互联公司!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。创新互联公司从2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联公司。
例如,
- SELECT COALESCE(NULL, NULL, NULL, GETDATE())
它将返回当前的日期。它略过第一个NULL值并返回第一个非空的值。
对Pivot(透视)使用Coalesce
如果你对AdventureWorks数据库运行下面的语句:
- SELECT Name
- FROM HumanResources.Department
- WHERE (GroupName = 'Executive General and Administration')
你将获得像下面的一个标准结果集。
如果你想透视数据,你可以运行下面的命令。
- DECLARE @DepartmentName VARCHAR(1000)
- SELECT @DepartmentName = COALESCE(@DepartmentName,'') + Name + ';'
- FROM HumanResources.Department
- WHERE (GroupName = 'Executive General and Administration')
- SELECT @DepartmentName AS DepartmentNames
并获得下面的结果集。
使用SQL ServerCoalesce来来执行多条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
我个人喜欢能够使用三行代码杀掉数据库中的所有事务。如果你曾经试过恢复数据库而不能获得专门的访问,你就知道这是多么有用的了。
- 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
这将得出一个类似于下面的结果集。
以上的相关内容就是对SQL ServerCoalesce的介绍,望你能有所收获。
【编辑推荐】
分享标题:SQL ServerCoalesce的大量使用的具体描述
文章出自:http://www.gawzjz.com/qtweb2/news5/12505.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联