利用SqlServer将Excel中的数据导入Oracle

本文提供一种间接把Excel中的数据导入Oracle中的方法:利用Sql Server和Excel的近亲关系,在Sql Server中利用OpenDataSource方法读取Excel,并把数据拼写成符合oracle的sql语句。

“只有客户发展了,才有我们的生存与发展!”这是创新互联建站的服务宗旨!把网站当作互联网产品,产品思维更注重全局思维、需求分析和迭代思维,在网站建设中就是为了建设一个不仅审美在线,而且实用性极高的网站。创新互联对做网站、网站设计、网站制作、网站开发、网页设计、网站优化、网络推广、探索永无止境。

在sql server中执行如下代码:

 
 
 
  1. SELECT 'update userinfo set Useducation = '''  
  2.  
  3. + CASE WHEN [现文化程度] IS NULLTHEN ''  
  4.  
  5. ELSE [现文化程度] END    
  6.  
  7. + CASEWHEN [技术等级] IS NULLTHEN ''  
  8.  
  9. ELSE ''', Usskilllevel = '''+ [技术等级] END +  ''''  
  10.  
  11. + CASEWHEN [加入党派日期] IS NULLTHEN ''  
  12.  
  13. ELSE ', Usdangtuantime = to_date('''+ CONVERT(VARCHAR(12), [加入党派日期], 110)+ ''',''mm-dd-yyyy'')' END  
  14.  
  15. + CASEWHEN [入路工作日期] IS NULLTHEN ''  
  16.  
  17. ELSE ', Usinputtime = to_date('''+ CONVERT(VARCHAR(12), [入路工作日期], 110)+ ''',''mm-dd-yyyy'')' END  
  18.  
  19. + CASEWHEN [出生日期] IS NULLTHEN ''  
  20.  
  21. ELSE ', Usbirthdate = to_date('''+ CONVERT(VARCHAR(12), [出生日期], 110)+''',''mm-dd-yyyy'')' END  
  22.  
  23. + ' where Uscardid ='''+ [身份证号] + ''';'  
  24.  
  25. FROM OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0',   
  26.  
  27. 'Data Source=D:\gongren.xls;Extended Properties=Excel 8.0')...[Sheet1$] 

需要注意:

1)请提供正确的文件路径和Sheet名称;

2)关闭要读取的Excel文件,否则会报错;

3)确保to_date函数对应的字段在Excel中为日期类型;

执行结果如下:

 
 
 
  1. update userinfo set Useducation = '中等专科', Usinputtime = to_date('12-25-2000','mm-dd-yyyy'), Usbirthdate = to_date('09-06-1976','mm-dd-yyyy') where Uscardid ='132430197609061413';   
  2.  
  3. update userinfo set Useducation = '大学', Usskilllevel = '中级工', Usdangtuantime = to_date('07-11-2000','mm-dd-yyyy'), Usinputtime = to_date('07-01-2003','mm-dd-yyyy'), Usbirthdate = to_date('08-21-1979','mm-dd-yyyy') where Uscardid ='132826197908210332';   
  4.  
  5. update userinfo set Useducation = '大专', Usskilllevel = '高级工', Usdangtuantime = to_date('07-03-2001','mm-dd-yyyy'), Usinputtime = to_date('01-01-2005','mm-dd-yyyy'), Usbirthdate = to_date('10-26-1980','mm-dd-yyyy') where Uscardid ='132421198006260032'; 

在pl/sql中执行上述代码就行了。

本文就介绍到这里,更多关于Oracle的内容请到这里:http://database./oracle/,谢谢大家的支持!

文章标题:利用SqlServer将Excel中的数据导入Oracle
文章起源:http://www.shufengxianlan.com/qtweb/news11/133061.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联