Oracle sqlldr导入数据使用默认值日期
2015-07-14 11:48
841 查看
做到项目需要向oracle中批量导入数据。表中有一个字段是Date类型。
生成ctl文件导入信息的时候,因为原来的txt中是没有这个date信息的,需要使用导入时候的时间数据插入到到列中。
原本的想法是java代码中获取到日期信息后,作为一个字符串的默认值(constant)插入到数据库中,但是试过网上各种方法,都不行。
最后的方法是使用数据库默认的时间,即sysdate。
最后执行成功的ctl文件内容为:
load data
infile 'F:\FTP_UPLOAD\SYKTyj\return\CC2055000320150709\JY2055000320150709.TXT'
append into table T_LIQ_IMP_CPU_JY
fields terminated by ' '
(
JY_PID,
JY_PSN,
JY_TIM,
TXT_NAME constant "JY2055000320150709.TXT",
ZIP_NAME constant "CC2055000320150709.ZIP",
TEMP_STAT constant "0",
IMP_TIME sysdate)
其中的IMP_DATE为日期类型,使用数据库的时间。TXT_NAME也是文件中没有的数据,数据库中对应为varchar2类型,使用constant后面的内容作为默认值插入。
生成ctl文件导入信息的时候,因为原来的txt中是没有这个date信息的,需要使用导入时候的时间数据插入到到列中。
原本的想法是java代码中获取到日期信息后,作为一个字符串的默认值(constant)插入到数据库中,但是试过网上各种方法,都不行。
最后的方法是使用数据库默认的时间,即sysdate。
最后执行成功的ctl文件内容为:
load data
infile 'F:\FTP_UPLOAD\SYKTyj\return\CC2055000320150709\JY2055000320150709.TXT'
append into table T_LIQ_IMP_CPU_JY
fields terminated by ' '
(
JY_PID,
JY_PSN,
JY_TIM,
TXT_NAME constant "JY2055000320150709.TXT",
ZIP_NAME constant "CC2055000320150709.ZIP",
TEMP_STAT constant "0",
IMP_TIME sysdate)
其中的IMP_DATE为日期类型,使用数据库的时间。TXT_NAME也是文件中没有的数据,数据库中对应为varchar2类型,使用constant后面的内容作为默认值插入。
相关文章推荐
- Oracle中varchar,varchar2,nvarchar,nvarchar2的区别及其它数据类型描述
- Oracle列转行函数Listagg以及pivot查询示例
- 查询oracle server端的字符集
- 使用PLSql连接Oracle时报错ORA-12541: TNS: 无监听程序
- [solaris]odbc-oracle,简单测试
- Oracle 11g必须开启的服务及服务详细介绍,oracle的命令大全
- [Oracle]Tablespace usage check
- oracle 11g密码永不过期
- sqlplus连接Oracle数据库超时
- Oracle数据库的导入导出
- oracle Database link 创建
- oracle时间数据格式的分析
- linux操作系统下,oracle db 11g中增大memory_max_target和memory_target应该注意的
- oracle update set 使用case when语句
- Oracle 调用java 初始(一)
- oracle创建用户及常用命令
- 【Oracle】数据库运行状态下物理删除所有redo日志恢复方法
- oracle中怎样获取当前月上个月的第一天和最后一天?
- oracle官方文档_查看初始化参数(举例)
- 修改oracle服务器端字符集