Oracle数据库查询一键导出Excel (oracle数据库 查询导出到excel)
前言
在现代商业活动中,交流和管理大量数据以及数据在业务中的应用显得尤为重要,为了方便数据的备份、传递、参考和分析等,将数据导出成 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 的过程是相对简捷的,而且能够在保证质量和效率的同时,减少数据处理的时间和成本。