oracle varchar2 转换成date,将Oracle VARCHAR2转换为DATE并排除无效数据

在尝试将Oracle数据库中VARCHAR2类型的column_name字段转换为DATE类型时,遇到ORA-01841错误,该错误提示年份输入范围不合法。尝试使用DECODE函数排除NULL和'00000000'值,但问题依然存在。数据中包含NULL、空格、'00000000'以及有效的日期字符串如'20161111'。解决方案需要能有效过滤无效数据并成功转换日期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我有列column_name VARCHAR2与各种数据。将其转换为DATE数据类型我写了下面的表达式:将Oracle VARCHAR2转换为DATE并排除无效数据

SELECT TO_DATE(column_name, 'YYYY/MM/DD') FROM schema.table;

但它给我的错误:

ORA-01841: (full) year must be between -4713 and +9999, and not be 0 01841. 00000 - "(full) year must be between -4713 and +9999, and not be 0"

*Cause: Illegal year entered

*Action: Input year in the specified range

柱包括NULL,space,00000000和字符串日期,如 “20161111”。

要排除无效数据,我决定使用DECODE:

SELECT DECODE(column_name,

'', NULL,

'00000000', NULL,

TO_DATE(column_name, 'YYYY/MM/DD'))

FROM schema.table;

但在这种情况下,我得到了以下错误:

ORA-01841: (full) year must be between -4713 and +9999, and not be 0 01841. 00000 - "(full) year must be between -4713 and +9999, and not be 0"

*Cause: Illegal year entered

*Action: Input year in the specified range

数据例如:

| # | column_name |

|---|-------------|

| 1 | 00000000 |

| 2 | |

| 3 | (null) |

| 4 | 20161111 |

什么时我做错了?

是否有解决方案排除所有无效的数据,而不包括在DECODE的情况下?

+0

你能显示一些来自列的示例数据吗? –

+1

请勿粘贴图片,请使用文字。 –

+0

你认为'20161111'有效吗? (即2016-11-11) –

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值