
都可以把空值替换成另外一个内容,你这里只需要把空值替换“null字符”就可以了。
oracle:select nvl(字段,'NULL') from ****
mysql:select ifnull(字段,''NULL'') from ****
sqlserver,也类似,我就不写了
nvl( ) 函数
语法:
NVL(eExpression1, eExpression2);
参数:
eExpression1, eExpression2。
如果 eExpression1 的计算结果为 null 值,则 NVL( ) 返回 eExpression2。如果 eExpression1 的计算结果不是 null 值,则返回 eExpression1。
eExpression1 和 eExpression2 可以是任意一种数据类型。如果 eExpression1 与 eExpression2 的结果皆为 null 值,则 NVL( ) 返回 .NULL.。
NVL( string1, replace_with)。
功能:如果string1为NULL,则NVL函数返回replace_with的值,否则返回string1的值。
引申一下,此NVL的作用与SQLserver 中的 ISNULL( string1, replace_with) 一样。
注意事项:string1和replace_with必须为同一数据类型,除非显式的使用TO_CHAR函数。
例:NVL(TO_CHAR(numeric_column), 'some string') 其中numeric_column代指某个数字类型的值。
例:nvl(yanlei777,0) >0。
NVL(yanlei777, 0) 的意思是 如果 yanlei777 是NULL, 则取 0值。
通过查询获得某个字段的合计值,如果这个值为null将给出一个预设的默认值。
扩展资料:
nvl函数例子:
select nvl(sum(t.dwxhl),1)
from tb_jhde t。
就表示如果sum(t.dwxhl) = NULL 就返回 1。
另一个有关的有用方法。
declare i integer。
select nvl(sum(t.dwxhl),1) into i from tb_jhde t where zydm=-1这样就可以把获得的合计值存储到变量。i中,如果查询的值为null就把它的值设置为默认的1。
oracle中:
select nvl(rulescore,0) from zwjc_graderule where rulecode='FWTD'
如果记录中不存在rulecode ='FWTD'的数据.则查不出数据。
select nvl(rulescore,0) into rule_score from zwjc_graderule where rulecode='FWTD'会报查不到数据的错。
select nvl(sum(rulescore),0) from zwjc_graderule where rulecode='FWTD'
如果记录中不存在rulecode ='FWTD'的数据.还是可以得到一行列名为nvl(rulescore,0),值为0的数据。
select nvl(sum(rulescore),0) rule_score from zwjc_graderule where rulecode='FWTD'不会报错。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)