sql查询没有数据的时候怎么用0填充
这样:
SELECT
a.dt AS '时间',
ISNULL(b.yield, '0') AS '数据'
FROM
(
SELECT
dateadd(d, number, '2018-11-01') dt
FROM
master..spt_values
WHERE
type = 'p'
AND dateadd(d, number, '2018-11-01') <= '2018-11-30'
) a
LEFT JOIN CE_BD_E_ELECTRIC_WORKSHIFT_T b ON a.dt = b.opdate
扩展资料:
注意事项
COALESCE是一个函数, (expression_1, expression_2, …,expression_n)依次参考各参数表达式,遇到非null值即停止并返回该值。如果所有的表达式都是空值,最终将返回一个空值。使用COALESCE在于大部分包含空值的表达式最终将返回空值。
场景一:你想要获取最大值,然后+1返回(即返回的值已经默认为空了),程序接收了本来不该为空的值去运算,就会出错。
SELECT MAX(my_money)+1 FROM tb_test;
改进方法:使用 coalesce函数 COALESCE(值1, 值2,......, 值n) ,只要遇到非null值就返回。
这样子就可以设置一个值,让你第一个不成功后,返回指定的值,如下面,返回的是1.
SELECT COALESCE(MAX(my_money)+1, 1) FROM tb_test;
如果是SQLServer数据库可以使用ISNULL()函数
例如:
--这是临时变量表
declare @table table(a varchar(20),b varchar(20))
insert into @table(a) values('a')
--实际查询语句
select a,b from @table
--测试查询语句,当无数据时用0代替
select a=isnull(a,0),b=isnull(b,0) from @table
效果图如下:
参考资料
了解更多关于ISNULL函数用法,可访问下面连接
这种方法不行哦,因为我查的数据数据库里是没有的所以他不是null而是没有那条记录
如果是空数据,返回0。你只能通过相应的程序判断,或者sql判断无法用一个查询,如果是空返回0的。
例如类似:
if exists(select 1 from 表名 where 条件语句)
begin--如果存在
select * from 表名 where 条件语句
end
else
begin--如果不存在
select 0
end
你这不是给他插入一条数据?
插入是insert into