日期:2014-05-17  浏览次数:21806 次

使用NVL函数报错
我的products表是有空值的

但是在使用NVL是就报错,请问是怎么回事?

------解决方案--------------------
'No Id'改成整数
------解决方案--------------------
你的product_type_id是number类型,不是字符串
------解决方案--------------------
同上
product_type_id是number类型,NVL(product_type_id,数值)就可以了啊
------解决方案--------------------
select nvl(null ,'ccc') from  dual;
select nvl('1' ,'c cc') from  dual;红字处为字符串。


------解决方案--------------------
改成nvl(product_type_id
------解决方案--------------------
'' ,'No id')
------解决方案--------------------
各楼的都是正解,呵呵
------解决方案--------------------
CMD面板下面有错误提示的invalid number,无效的数字。
说明你使用NVL函数的时候给定的默认值类型,与product_type_id不匹配了。
而你给出的恰恰是不匹配的值'no id'字符类型。所以才出错!
看你写的查询语句应该也是无实际意义的,你可以修改当product_type_id为null时,让默认值为一个任意NUMBER类型的数值。
如:
SELECT NVL(product_type_id, 0), name FROM products;
------解决方案--------------------
支持2楼的见解