相关疑难解决方法(0)

如何识别存储在Oracle DATE列中的无效(损坏)值

Oracle 10.2.0.5

在DATE列中标识表中具有"无效"值的行的最简单方法是什么.这里的"无效"是指我的意思是违反Oracle日期值规则的二进制表示.

我最近遇到了一个存储在列中的无效日期的问题.

我能够使用查询谓词来查找特定的有问题的行:

  WHERE TO_CHAR(date_expr,'YYYYMMDDHH24MISS') = '00000000000000'
Run Code Online (Sandbox Code Playgroud)

在我的情况下,世纪字节无效......

 select dump(h.bid_close_date) from mytable h where h.id = 54321

 Typ=12 Len=7: 220,111,11,2,1,1,1
Run Code Online (Sandbox Code Playgroud)

世纪字节应该是100 +两位数世纪.在这种情况下,增加了额外的100,好像世纪价值是"120",使得年份"12011".(我知道将无效DATE值引入数据库的唯一方法是使用OCI,使用本机7字节DATE表示.)

在这种情况下,TO_CHAR函数返回一个可识别的字符串,我可以用它来识别不稳定的DATE值.

我的问题:是否有更通用或更简单的方法(最好使用SQL SELECT语句)来识别DATE列中具有"无效"值的行.

sql oracle date oracle10g

13
推荐指数
2
解决办法
2万
查看次数

如何处理SELECT语句中的to_date异常以忽略这些行?

我有以下查询,我试图在我正在处理的水晶报表中用作COMMAND.

SELECT * FROM myTable
WHERE to_date(myTable.sdate, 'MM/dd/yyyy') <= {?EndDate}
Run Code Online (Sandbox Code Playgroud)

这很好用,但我唯一担心的是日期可能并不总是格式正确(由于用户错误).我知道当to_date函数失败时会抛出异常..是否有可能以忽略SELECT语句中相应行的方式处理此异常?因为如果整个数据库中只有一个日期格式不正确,我的报告就会中断.

我查看Oracle是否提供了isDate函数,但看起来您应该只处理异常.任何帮助将不胜感激.谢谢!!

oracle crystal-reports

8
推荐指数
4
解决办法
3万
查看次数

标签 统计

oracle ×2

crystal-reports ×1

date ×1

oracle10g ×1

sql ×1