SQL Server ISNULL 不生效原因

时间:2019-02-19
本文章向大家介绍SQL Server ISNULL 不生效原因,主要包括SQL Server ISNULL 不生效原因使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

数据库:SQL Server 2008 R2

原始SQL:historyval 字段没有数据显示为NULL,用ISNULL判断为NULL的时候替换为 0.0

SELECT
	ISNULL(historyval, 0.0)
FROM
	ce_bf_l_energyh_t_2
WHERE
	tagname = '123'

 

问题:用ISNULL只后数据依旧为NULL并没有替换掉。

原因:ISNULL只作用于查询出数据后字段为NULL可以替换生效、如果查询的时候这条数据本身为NULL、字段替换时ISNULL则不生效。

 

解决方法:先用 if exists(结果集)判断这条数据是否存在(也就是说这条select这条sql有没有结果集),BEGIN 表示语句块的开始;END 表示语句块的结束(加不加 BEGIN  END 代码块都可以)。如果满足条件直接在下方写 SQL。不满足条件时,则在 ELSE 下方写 SQL。如此,数据进行了替换。 

IF EXISTS (
	SELECT
		ISNULL(historyval, 0.0)
	FROM
		ce_bf_l_energyh_t_2
	WHERE
		tagname = '123'
)
BEGIN
	--如果存在
	SELECT
		ISNULL(historyval, 0.0)
	FROM
		ce_bf_l_energyh_t_2
	WHERE
		tagname = '123'
	END
	ELSE

	BEGIN
		--如果不存在
		SELECT
			0.0
		END