WEB开发网
开发学院数据库Oracle sqlldr的用法总结 阅读

sqlldr的用法总结

 2008-12-17 13:06:00 来源:WEB开发网   
核心提示: 4 * position的列子LOAD DATAINFILE *INTO TABLE DEPTREPLACE( DEPTNO position(1:2),DNAME position(*:16), // 这个字段的开始位置在前一字段的结束位置LOC position(*:29),ENTIR

4 ***** position的列子

  LOAD DATA
  INFILE *
  INTO TABLE DEPT
  REPLACE
  ( DEPTNO position(1:2),
  DNAME position(*:16), // 这个字段的开始位置在前一字段的结束位置
  LOC position(*:29),
  ENTIRE_LINE position(1:29)
  )
  BEGINDATA
  10Accounting Virginia,USA

5 ***** 使用函数 日期的一种表达 TRAILING NULLCOLS的使用

  LOAD DATA
  INFILE *
  INTO TABLE DEPT
  REPLACE
  FIELDS TERMINATED BY ','
  TRAILING NULLCOLS // 其实下面的ENTIRE_LINE在BEGINDATA后面的数据中是没有直接对应
  // 的列的值的 如果第一行改为 10,Sales,Virginia,1/5/2000,, 就不用TRAILING NULLCOLS了
  (DEPTNO,
  DNAME "upper(:dname)", // 使用函数
  LOC "upper(:loc)",
  LAST_UPDATED date 'dd/mm/yyyy', // 日期的一种表达方式 还有'dd-mon-yyyy' 等
  ENTIRE_LINE ":deptno||:dname||:loc||:last_updated"
  )
  BEGINDATA
  10,Sales,Virginia,1/5/2000
  20,Accounting,Virginia,21/6/1999
  30,Consulting,Virginia,5/1/2000
  40,Finance,Virginia,15/3/2001

6 ***** 使用自定义的函数 // 解决的时间问题

  create or replace
  function my_to_date( p_string in varchar2 ) return date
  as
  type fmtArray is table of varchar2(25);
  l_fmts fmtArray := fmtArray( 'dd-mon-yyyy', 'dd-month-yyyy',
  'dd/mm/yyyy',
  'dd/mm/yyyy hh24:mi:ss' );
  l_return date;
  begin
  for i in 1 .. l_fmts.count
  loop
  begin
  l_return := to_date( p_string, l_fmts(i) );
  exception
  when others then null;
  end;
  EXIT when l_return is not null;
  end loop;
  if ( l_return is null )
  then
  l_return :=
  new_time( to_date('01011970','ddmmyyyy') + 1/24/60/60 *
  p_string, 'GMT', 'EST' );
  end if;
  return l_return;
  end;
  /
  LOAD DATA
  INFILE *
  INTO TABLE DEPT
  REPLACE
  FIELDS TERMINATED BY ','
  TRAILING NULLCOLS
  (DEPTNO,
  DNAME "upper(:dname)",
  LOC "upper(:loc)",
  LAST_UPDATED "my_to_date( :last_updated )" // 使用自定义的函数
  )
  BEGINDATA
  10,Sales,Virginia,01-april-2001
  20,Accounting,Virginia,13/04/2001
  30,Consulting,Virginia,14/04/2001 12:02:02
  40,Finance,Virginia,987268297
  50,Finance,Virginia,02-apr-2001
  60,Finance,Virginia,Not a date

上一页  1 2 3 4  下一页

Tags:sqlldr 用法 总结

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接