sql中的coalesce

本文详细介绍了SQL中的COALESCE函数,包括其返回第一个非NULL值的特性,以及在Pivot、多条SQL命令执行和解决并发问题等场景中的应用示例。
摘要由CSDN通过智能技术生成

先解释coalesce含义:coalesce函数返回参数(列名)中第一个非NULL的字段值,注意不是为空'' 。

看例子:

--创建表
IF OBJECT_ID('#'IS NOT NULL   DROP TABLE #
CREATE TABLE #(
    COL1 
VARCHAR(10),
    COL2 
VARCHAR(10),
    COL3 
VARCHAR(10)
)
GO
--插入数据
INSERT INTO # SELECT NULL,'COL2',''
--查询
SELECT coalesce(COL1,COL2,COL3) FROM #
--结果是
/*

COL2
*/

但是如果该字段中所有的值都是NULL,coalesce将返回NULL!

---------------------------------------

以上是我们至少要了解的,想知道更多往下看


很多人知道ISNULL函数,但是很少人知道Coalesce函数,人们会无意中使用到Coalesce函数,并且发现它比ISNULL更加强大,其实到目前为止,这个函数的确非常有用,本文主要讲解其中的一些基本使用:


首先看看联机丛书的简要定义:返回其参数中第一个非空表达式,语法如下

COALESCE ( expression [ ,...n ] ) 

  如果所有参数均为 NULL,则 COALESCE 返回 NULL。至少应有一个 Null 值为 NULL 类型。尽管 ISNULL 等同于 COALESCE,但它们的行为是不同的。包含具有非空参数的 ISNULL 的表达式将视为 NOT NULL,而包含具有非空参数的 COALESCE 的表达式将视为 NULL。在 SQL Server 中,若要对包含具有非空参数的 COALESCE 的表达式创建索引,可以使用 PERSISTED 列属性将计算列持久化,如以下语句所示:

[sql]  view plain   copy
  print ?
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值