微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

数据库 – Oracle外部表 – 指定动态文件名

CREATE TABLE LOG_FILES (
        LOG_DTM VARCHAR(18),LOG_TXT VARCHAR(300)
   )
 ORGANIZATION EXTERNAL(
   TYPE ORACLE_LOADER
   DEFAULT DIRECTORY LOG_DIR
   ACCESS ParaMETERS(
      RECORDS  DELIMITED BY NEWLINE
      FIELDS(
        LOG_DTM position(1:18),LOG_TXT position(19:300)
      )
   )
   LOCATION('logadm'))
)
REJECT LIMIT UNLIMITED
/

LOG_DIR是一个oracle目录,指向/ u / logs /

但问题是/ u / logs /的内容看起来像这样

logadm_12012012.log
logadm_13012012.log
logadm_14012012.log
logadm_15012012.log

有什么办法可以动态指定文件的位置吗?即每次我从LOG_FILES运行Select *时,它应该使用当天的日志文件. (例如log_adm_DDMMYYYYY).

我知道我可以使用alter table log_files location(‘logadm_15012012.log’),但我不想发出alter命令.

还有其他可能吗?

谢谢

解决方法

你跑10g真是太遗憾了.在11g上,我们可以将预处理器脚本(shell脚本)与外部表相关联.在您的情况下,您可以运行一个脚本,该脚本将找出最新文件,然后发出复制命令.就像是:
cp logadm_15012012.log logadm

Adrian Billington的博客大约是this feature here.坦率地说,他的写作比the official docs更有帮助.

但是,当您使用10g时,您可以执行ALTER TABLE语句,或使用预定作业(cron或其他)将新文件与通用名称同步.

原文地址:https://www.jb51.cc/mssql/77218.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐