【问题标题】:Oracle SQLLDR - Load Record with Invalid Date, Replace Invalid Date with NullOracle SQLLDR - 使用无效日期加载记录,用 Null 替换无效日期
【发布时间】:2018-06-13 23:19:53
【问题描述】:

我的源文本文件中存在日期值无效的记录。由于手动输入,无效日期值的格式不一致。我仍然想加载所有这些记录,但我想用 null 替换无效的日期值。

请让我知道这是否/如何通过 SQLLDR 控制文件命令实现。我想避免创建任何自定义函数。一些简单的,通常是指错误/异常并且有效(与下面不同)是理想的:

DATE "MM/DD/YYYY" NULLIF (FROM_DOS=EXCEPTION)

谢谢!

【问题讨论】:

  • 一些实际的样本数据将有助于了解我们正在处理的内容。编辑原始帖子以包含好的和坏的日期数据。

标签: oracle date sql-loader ctl nullif


【解决方案1】:

据我所知,这不会一次性完成。我建议你尝试一种相对简单的方法:

  • “按原样”加载原始数据
    • 日期无效的行不会被加载,但会在 .BAD 文件中结束
  • 然后修改控制文件:
    • 源现在是 .BAD 文件
    • 将 NULL 加载到日期列中(FILLER 可能会有所帮助)

或者,您可以将源文件用作外部表,并针对它编写 (PL/)SQL 以将数据加载到目标表中。它允许您实际编码任何您想要的,但是 - 正如您所说,您不想创建自定义函数(它将决定输入数据是否 - 或不是 - 有效的 DATE 值),我想你宁愿跳过那个选项。

【讨论】:

  • 这是我决定使用的解决方案。它处理任何格式无效的日期(尽管不处理适当格式的无效值)。 "CASE WHEN :FROM_DOS NOT LIKE '##/##/####' THEN NULL ELSE to_date(:FROM_DOS, 'MM/DD/YYYY') END"
  • 如果目标列是 DATE 数据类型,这对于格式有效(##/##/####)但值无效(例如 67/43/0987)的输入数据将失败),所以...
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2019-02-11
  • 1970-01-01
  • 2022-01-23
  • 2017-04-04
  • 2014-06-24
  • 1970-01-01
  • 2014-05-20
相关资源
最近更新 更多