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 的过程是相对简捷的,而且能够在保证质量和效率的同时,减少数据处理的时间和成本。


数据运维技术 » Oracle数据库查询一键导出Excel (oracle数据库 查询导出到excel)