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

相关问题拓展阅读:

如何使用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)