加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

sql – 怎样辨认存储在Oracle DATE列中的无效(破坏)值

发布时间:2021-01-18 01:54:26 所属栏目:编程 来源:网络整理
导读: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子句更新,我发此刻这些环境下月份数为零.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读