前言
在现代商业活动中,交流和管理大量数据以及数据在业务中的应用显得尤为重要,为了方便数据的备份、传递、参考和分析等,将数据导出成 Excel 是一种简单而有效的途径,本文讲述的就是如何在 Oracle 数据库中实现一键导出 Excel。
一、什么是 Oracle 数据库?
Oracle 数据库是一个以多用户为中心的、由 Oracle Corporation 公司开发的数据库管理系统,它是市场上更受欢迎的企业级数据库之一,常常使用在财务、制造、物流和公关等领域。
二、Oracle 导出 Excel 主要有哪些方式?
1、使用 SQL 工具,手动执行导出 SQL 语句到 CSV 或 XLSX 文件;
2、使用 APEX,通过提供的导出组件(APEXExport,其内部也是使用 SQL 对数据进行查询,再转换为 XLSX 格式)实现数据导出;
3、使用 PL/SQL 开发工具进行开发,将查询结果写入到 Excel 模板中,最终实现数据导出。
三、使用 PL/SQL 开发工具实现 Oracle 数据库一键导出 Excel
直接调用 DBMS_SQL 的 EXECUTE 方法执行 SQL 语句是一种实现方案,该方法不用查询数据、生成结果集并写入文件,从而可以保证异常的场景下也不会有占用过多系统资源的情况。以下是一些具体的代码实现。
1、安装 PL/SQL 包:OraExcel
本包提供了通过 SQL 语句导出 Excel 文档的功能,最新版本兼容 Oracle 19c。
2、将数据导入模板
宏模板结构如下图所示:
Template Sheet
Sheet1
Sheet2
…
宏模板的格式可以是.xls 或 .xlsx 格式,其中 sheet 的名称可以是任意的,而且 excel 中可以设置任何的样式。
3、编写代码
以下是一份基于 Oracle 和 OraExcel 组成的 SQL 查询,它用于生成一个导出 Excel 表格的基础框架:
DECLARE
excel_file_name varchar2(100) := ‘example.xlsx’;
vdb_cursor integer;
vsql varchar2(4000);
BEGIN
vsql :=
q'[SELECT /*+ ORDERED */
‘SheetName_1’ as “SheetName”,
winter.price as “Winter_Price” from winter]’;
— Create the cursor.
vdb_cursor := DBMS_SQL.OPEN_CURSOR;
— Execute the SQL.
DBMS_SQL.PARSE(vdb_cursor, vsql, DBMS_SQL.NATIVE);
— Retrieve the description structure.
DBMS_SQL.DESCRIBE_COLUMNS(vdb_cursor, vcols);
— Create the columns record type.
vcols_type :=
dbms_sql.define_column_table(vdb_cursor, vdesc_count, vtype_count);
— Note that the columns record type returned by DBMS_SQL is in reverse order to the
— column order returned by DESCRIBE_COLUMNS, so we need to populate it in reverse
— order.
REPEAT
vdesc_count := vdesc_count + 1;
IF (vcols(vdesc_count).col_type = dbms_sql.TYPE_VARCHAR2) THEN
vcol_tab(vdesc_count).varchar2_col := NULL;
ELSE
rse_application_error(-20231, ‘Unknown column type’);
END IF;
vtype_tab(vtype_count) := vcols(vdesc_count).col_type;
vtype_count := vtype_count + 1;
UNTIL (vdesc_count >= vcols.last_column);
— Create the buffer.
buf := dbms_sql.varchar2s(1, 4000, TRUE);
— Open and write the Excel file.
oraexcel.new_document;
oraexcel.set_paper_size(21, 29.7);
oraexcel.add_sheet(vsheet_count, ‘SheetName_1’);
oraexcel.query_to_sheet(1, ‘Winter’, vdb_cursor, vcols, vcols_type, FALSE, ‘B5’, ‘F5’, null);
oraexcel.save_to_file(excel_file_name);
— Close the cursor.
DBMS_SQL.CLOSE_CURSOR(vdb_cursor);
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR(vdb_cursor);
RSE;
END;
4、测试运行生成的 Excel 文件
使用文本编辑器打开生成的 Excel 文档,可以看到数据已经按照所需格式填写在了表格中。
四、结论
在完成本篇文档所述的实验之后,我们发现使用 PL/SQL 开发工具实现 Oracle 数据库一键导出 Excel 的过程是相对简捷的,而且能够在保证质量和效率的同时,减少数据处理的时间和成本。
相关问题拓展阅读:
如何使用PL/SQL工具将oracle数据导出到excel
1、首先SQL Window窗口查询需要导数据
2、查询结集(注意要选任何行或者单元格)右键–【Copy to Excel】–>【Copy as xls/xlsx】导格式.xls或者2023xlsx文件.
3、想导查询全部数据左侧选需要导行步奏同
4、点击导系统自打导excel文件内容面包括数据及查询些数据sql脚本
5、点击SQL Statement查看数据库脚本
6、面操作excel文件点击【文件】–【另存】保存excel文件
7、选择保存路径输入文件名称
注意事项:导excel候行记录数自导需要excel列删除即
如何使用PL/SQL工具将oracle数据导出到excel
之一步晌陆,在pl/sql窗口查询出你想要导出的数据。
第二步,选择你想导出的数据,然后旦弊右键“复制到Excel”即可,宴迟顷如下图所示:
关于oracle数据库 查询导出到excel的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
来源地址:Oracle数据库查询一键导出Excel (oracle数据库 查询导出到excel)
转载声明:本站文章若无特别说明,皆为原创,转载请注明来源:www.88531.cn资享网,谢谢!^^