sql – 如何识别存储在Oracle DATE列中的无效(损坏)值
发布时间:2021-01-17 11:15:00 所属栏目:MsSql教程 来源:网络整理
导读:Oracle 10.2.0.5 在DATE列中标识表中具有“无效”值的行的最简单方法是什么.这里的“无效”是指我的意思是违反Oracle日期值规则的二进制表示. 我最近遇到了一个存储在列中的无效日期的问题. 我能够使用查询谓词来查找特定的有问题的行: WHERE TO_CHAR(date_e
Oracle 10.2.0.5 在DATE列中标识表中具有“无效”值的行的最简单方法是什么.这里的“无效”是指我的意思是违反Oracle日期值规则的二进制表示. 我最近遇到了一个存储在列中的无效日期的问题. 我能够使用查询谓词来查找特定的有问题的行: WHERE TO_CHAR(date_expr,'YYYYMMDDHH24MISS') = '00000000000000' 在我的情况下,世纪字节无效…… select dump(h.bid_close_date) from mytable h where h.id = 54321 Typ=12 Len=7: 220,111,11,2,1,1 世纪字节应该是100两位数世纪.在这种情况下,增加了额外的100,好像世纪价值是“120”,使年份“12011”. (我知道在数据库中获取无效DATE值的唯一方法是使用OCI,使用本机7字节DATE表示.) 在这种情况下,TO_CHAR函数返回一个可识别的字符串,我可以用它来识别不稳定的DATE值. 我的问题:是否有更通用或更简单的方法(最好使用SQL SELECT语句)来识别DATE列中具有“无效”值的行. 解决方法这标识了无效月份SELECT rowid,pk_column,DUMP(date_column,1010) AS dump1 FROM table WHERE TO_NUMBER(SUBSTR(DUMP(date_column,1010),INSTR(DUMP( date_column,',2 ) + 1,INSTR(DUMP(date_column,3) - ( INSTR(DUMP( date_column,2) + 1 ))) = 0; 使用相同的where子句更新,我发现在这些情况下月份数为零. (编辑:91站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读