Oracle根据excel创建新表,从Oracle数据库创建Excel电子表格

我想问题是,你的“复杂结构”有多复杂?

编程IDE(如Oracle SQL Developer或Quest TOAD)具有向导将数据表导出为CSV文件的向导.

如果要连接多个表中的数据,可以使用视图,甚至编写SQL语句

select e.ename||','||d.dname

from emp e

join dept d on ( e.deptno = d.deptno )

/

(重新声明列通常可以包含逗号的数据,因此您可能希望使用更不寻常的字符 – 或字符集 – 作为分隔符.)

另一种快速做事的方法是使用SQL * Plus的HTML报告功能.许多电子表格工具可以在没有抓取的情况下导入结构良好的HTML和XML. Find out more.

如果你想要压缩层次结构或更复杂的东西,你可能需要进入PL / SQL.手动方法将使用上述语句的变体来使用UTL_FILE:

declare

csv_fh utl_file.filetype;

begin

csv_fh := utl_file.fopen('C:\temp', 'data_export.csv', 'W');

for r in ( select e.ename, d.dname

from emp e

join dept d on ( e.deptno = d.deptno )

) loop

utl_file.put_line(csv_fh, r.ename||'|'||r.dname;

end loop;

utl_file.fclose(csv_fh);

end;

如果要专门导出到Excel(即.XLS文件),那么您需要超越Oracle内置函数.直接从PL / SQL导出到Excel的常用解决方案是Tom Kyte用于SYLK api的OWA_SYLK包装器. Find out more.

这适用于单个工作表.如果要导出到多个工作表,可以使用几种替代解决方案.

Sanjeev Sapre有他的get_xl_xml包.顾名思义,它使用XML进行转换. Find out more.

Jason Bennett编写了一个生成Excel XML文档的PL / SQL对象. Find out more.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值