oracle01722(oracle01722无效数字)

本篇文章给大家谈谈oracle01722,以及oracle01722无效数字对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

oracle数据库报错“ora-01722:invalid number”,怎么解决?

数据库表中有一个varchar2类型的字段,里边可能包含数字或用逗掘察号分隔的数据,如3或4,5这样的值,查询时,只传入了一个数字,也就是不带逗号的参数。因此sql语句类似这样:

select * from ct where nos = 3

语句本身一看就知道会出问题,因为3没加引号,会被当作数字处理。这样就肯定会报ORA-01722: invalid number的错误:

SQL Error: 1722, SQLState: 42000

ORA-01722: invalid number

但在用hibernate时,为了避免数字问题,我们经常会这样写hsql语句:

String sql = 'select * from ctEntity as ct where ct.Nos = ''+no+''';

当传入参数no为‘4,5’时,可能不会报错,但当no为'4'或'5'时,也就是单个数字时,就会报错了。经过打印hibernate的语句,发现单个数字时,hibernate会把上述语句转义成这样:

select ct.Nos from ctEntity as ct where ct.Nos=4

也就是会忽略掉引号,这样数据库就会报错,因为varchar2类型的nos字段在查询时给转义成了数字,所以肯定报错了。

这种情况下,hsql语句就不能用 ct.Nos = ' ***'这样的写法,必须用like,如ct.Nos like '%no%',这样才不会报错。当然完整的查询语句要考虑逗号的前、后以及没有逗号的情况,那就自己考虑了。

1、xxx.txt

文高埋本内容:

XXXXXXXXXXXX XXXXX XXXXXXXXX X X X X XXXX

XXXXXXXXXXXX XXXXX XXXXXXXXX X X X X XXXX

2、XXX.ctl

....................................

INTO TABLE XXX_XXX_XXX -- 要插入记录的表

Fields terminated by ' ' -- 数据中每行记录用 空格 分隔

trailing nullcols --表的字段没有对应的值时允许为空

(

REQUEST_ID,

REQUEST_TIME DATE 'YYYYMMDDHH24MISS',

REQUEST_SOURCE INTEGER EXTERNAL ,

BUSINESS_TYPE INTEGER EXTERNAL ,

PAY_TYPE INTEGER EXTERNAL ,

CARD_WHOLECOUNT INTEGER EXTERNAL,

CARD_WHOLEVALUE INTEGER EXTERNAL,

PAY_AMOUNT INTEGER EXTERNAL

)

3、利用sqlloader导入会出现ORA-01722:invalid number问题;

原因:换行符的存在,如果integer或者number类型的栏位位于表的最后,最后其实会有CR/LF的换行符,在用sqlldr导入时会把换行符也算作那个数字的一部分,使得对应的导入PAY_AMOUNT 的值与PAY_AMOUNT在数据库中定义的NUMBE R(8)类型不匹配,从而出错。解决办法加integer或者加“TERMINATED BY WHITESPACE”。

即:

trailing nullcols --表的字段没有对应的值时允许为空

(

REQUEST_ID,

REQUEST_TIME DATE 'YYYYMMDDHH24MISS',

REQUEST_SOURCE INTEGER EXTERNAL ,

BUSINESS_TYPE INTEGER EXTERNAL ,

PAY_TYPE INTEGER EXTERNAL ,

CARD_WHOLECOUNT INTEGER EXTERNAL,

CARD_WHOLEVALUE INTEGER EXTERNAL,

PAY_AMOUNT INTEGER EXTERNAL TERMINATED BY WHITESPACE

)

注:在实际工戚散蚂程项目中,其实要导入9个字段,最后一个字段为导入时间,于是相应的在数据库中创表时,默认导入时间值为SYSDATE

IMPORT_DATE DATE DEFAULT SYSDATE

Oracle报错ORA-01722: 无效数字排查解决方案

在做报表系统的过程中,遇到了一个很有意思的问题,就是Oracle报了一个错 java.sql.SQLException: ORA-01722: 无效数字 ,正常来说,报该错就意味着数据类型不匹配,但是因为同一sql语句,多加了一个条件,就查出结果,不加条件,反而报错,所以就意味着,可能数据有误(或者语句有误),但是哪一条数据有误,肉眼难以识御纤迹别!

有一个机构表,存10个机构, is_use=‘0’ 意味着无效,不统计, is_use=‘1’ 意味着有效,参与统计,先看sql:

这个是公共的sql部分,往后添加条件,即可查竖凯相应结果:

查昆明能查出结果,但是查云南的时候,就报错,所以一怒之下,把ynCheckSql语句结果查出来,一条一条检验,还真发现了问题:

针对德宏这一个地方,查询的时候报了 ORA-01722: 无效数字 错误,仔细查看数据源,发现数据也没什么问题,因为计算过程中,会报除数不能为0的错,而该条数据有一个值( 该值是分母,也就是除数 ),我们都知道,除数不能为0,所以Oracle针对除数为0的情况,有一个函数:

所以为了直接返回结果,除数为0时直接返回镇并 - 如这个sql语句: ROUND(DECODE(ba.personal_plan,0,'-',(r.p5_year_inc+r.p6_year_inc+r.p7_year_inc+r.p8_year_inc+r.p9_year_inc+r.p10_year_inc)/ba.personal_plan*100),3) perPlan

我们都知道ROUND函数是保留小数位数,如果返回 - ,ROUND函数肯定会包无效数字错误,所以如果除数为0,直接返回特殊字符9999即可,后面再对9999进行单独处理!!

Oracle数据库查询,一直报错ORA-01722: 无效数字

你罩迅看一下物做此胡辩,billion应该有非数字的内容

转成字符进行比较

select * from A,B where to_char(A.CourseNum)=B.billon;

[img]

ora-01722怎么办

出现ORA-01722和ORA-27010的原因是多方面的:主要是oracle当岁猜前的服务不可用,shared memory realm does not exist,是因为oracle没有启动或没有正常启动,共享内存并没有分配给当前实例.所以,通过设置实例名,扒汪再用操作系统身份验证的方式,启动数据库。这样数据库就正春雀仔常启动了,就不会报ORA-01034和ORA-27101两个启动异常了。

还有就是可能是登录数据库后,不正常的退出,比如直接关掉窗口,而这时数据库里有未完成的动作,再次登录时就会提示“insufficient privileges”的报错,SQLshutdown immediate; SQLstartup;就恢复正常了。

最后可能你虚拟机的共享内存问题,看下数据库的配置文件是否对应了512M内存?还是你设置的大了,本身给的不足

关于oracle01722和oracle01722无效数字的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

Powered By Z-BlogPHP 1.7.2

备案号:蜀ICP备2023005218号