存储过程运行经常报“ORA-01406: 读取的列值被截断”错误,我现在想通过异常处理捕获到这个错误,不用exception when others then,只捕获这个错误,exception when XXX then ,XXX部分应该怎么写呢?
解决方案 »
- 问一个PLSQL的问题。。。谢谢
- oracle自动同步数据到sqlsever2000
- 存储过程的问题
- jdbc调用存储过程的问题。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
- 请问一个关于insert into的问题
- PROC中ORACLE数据库的游标以及CHAR型数据查询出来后的具体内容
- 表分区
- 请较缩排显示的问题,sqlplus显示的问题
- 想查找某个字段值的第一个字母为A的记录,如何写SQL语句呢?谢谢
- replace(替换字符串某一位)的问题?
- Oracle Forms Developer Release 6i 能在XP上安装吗?
- 编译时出错,提示信息:ld: Unsatisfied symbol "sqlcxt" in file spacct.o
if sqlerror=1406
...
你可以用下面的方法:
EXCEPTION
WHEN OTHERS THEN
IF sqlcode = -1406 then
注意这个值是负数。
OTHERS处理器应该是异常处理块中的最后的异常处理器,因为它是用来捕获除了别的异常处理器处理以外的所有的Oracle异常,所以在程序的最外层使用一个OTHERS处理器的话,将可以确保所有的错误都会被检测到。在一个内在的异常中,SQLCODE返回Oracle错误的序号,而SQLERRM返回的是相应的错误消息,错误消息首先显示的是错误代码。SQLCODE返回的是负数,除非Oracle的错误为“ORA-01403:NO DATA FOUND”(译:ORA-01403:未找到数据),当Oracle错误为“ORA-01403:NO DATA FOUND”时,其对应的SQLCODE为+100。对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception。一个Oracle的错误消息最多只能包含512个字节的错误代码。如果没有异常被触发,则SQLCODE返回0,SQLERRM返回“ORA-0000:normal, successful completion”。EXCEPTION
WHEN OTHERS THEN
IF sqlcode = -1406 then
这个可能是可以的,我刚才用no_data_found试了半天,sqlcode总是100,原来这个异常是特殊的,楼主试试吧
WHEN OTHERS THEN
IF sqlcode = -1406 then 这样的确可以。