当前位置: 首页 > news >正文

oracle使用PLSQL导出表数据

数据库课上布置了一个作业

利用PL/SQL语言,编写一个存储过程实现针对单张表的数据导出功能,要求将给定表的数据转换成SQL语言的Insert语句,并保存在文件中。该过程以要导出的表名和保存SQL语句的文件名为参数。

在网上尝试搜索了一下,中文网里没找到合适的参考文章,要么是针对特定表结构,要么是只导出特定数量的列,于是自己完成后写篇记录。

首先需要定义一个导出目录,这里定义了“EXPORT_DIR”

CREATE DIRECTORY EXPORT_DIR AS 'D:/';

然后创建存储过程,其中,BEGIN后的第一行有用到刚刚定义的导出目录,如果定义的导出目录与我不同,那么请修改这一行的导出目录。

CREATE OR REPLACE PROCEDURE EXPORT_CONT( p_table_name VARCHAR2, -- table name p_file_name VARCHAR2 -- filename ) AS l_cursor_handle INTEGER; l_dummy NUMBER; l_col_cnt INTEGER; l_rec_tab DBMS_SQL.DESC_TAB; l_current_col NUMBER(16); l_current_line VARCHAR2(2047); l_column_value VARCHAR2(300); l_file_handle UTL_FILE.FILE_TYPE; l_print_text VARCHAR2(100); l_record_count NUMBER(16) := 0; BEGIN --------------- 如果定义的目录不是EXPORT_DIR,那么请修改这一行 l_file_handle := UTL_FILE.FOPEN('EXPORT_DIR', p_file_name, 'a', 2047); l_cursor_handle := DBMS_SQL.OPEN_CURSOR; DBMS_SQL.PARSE(l_cursor_handle, 'SELECT * FROM '|| p_table_name, DBMS_SQL.native); l_dummy := DBMS_SQL.EXECUTE(l_cursor_handle); DBMS_SQL.DESCRIBE_COLUMNS(l_cursor_handle, l_col_cnt, l_rec_tab); l_current_col := l_rec_tab.FIRST; IF (l_current_col IS NOT NULL) THEN LOOP DBMS_SQL.DEFINE_COLUMN(l_cursor_handle, l_current_col, l_column_value, 300); l_current_col := l_rec_tab.NEXT(l_current_col); EXIT WHEN (l_current_col IS NULL); END LOOP; END IF; LOOP EXIT WHEN DBMS_SQL.FETCH_ROWS(l_cursor_handle) = 0; l_current_line := 'INSERT INTO ' || p_table_name || ' VALUES ('''; FOR l_current_col IN 1..l_col_cnt LOOP DBMS_SQL.COLUMN_VALUE (l_cursor_handle, l_current_col, l_column_value); l_print_text := l_column_value || ''','''; IF l_current_col =l_col_cnt then l_current_line := l_current_line || l_column_value || ''');'; ELSE l_current_line := l_current_line || l_column_value || ''','''; END IF; END LOOP; l_record_count := l_record_count + 1; UTL_FILE.PUT_LINE (l_file_handle, l_current_line); END LOOP; UTL_FILE.FCLOSE (l_file_handle); DBMS_SQL.CLOSE_CURSOR(l_cursor_handle); END;

运行存储过程(需要将第一个参数修改为自己想要导出的表名)。

call EXPORT_CONT('PROJECTS_110', 'proj.sql');

在导出目录下找到对应文件,确定内容确实为表的数据。

INSERT INTO PROJECTS_110 VALUES ('CXCY20231010','创新项目','校级','基于AI的智能诊断系统','8208220101','S001','5000','01-1月 -23','31-12月-23'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023001','创新项目','校级','基于AI的智能诊断系统','8208220101','S001','5000','01-1月 -23','31-12月-23'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023002','创业项目','省级','智能家居控制系统','8208220105','S001','12000','01-3月 -23','28-2月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023003','创新项目','国家级','新能源材料研究','8208220110','S001','25000','01-6月 -23','31-5月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023004','创业项目','校级','校园智能无人超市','8208220115','S001','8000','01-7月 -23','30-6月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023005','创新项目','省级','农业智能检测系统','8208220120','S001','15000','01-9月 -23','31-8月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023006','创新项目','校级','智能校园管理平台','8218220110','S002','6000','01-1月 -23','31-12月-23'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023007','创业项目','省级','电商平台优化系统','8218220115','S002','14000','01-2月 -23','31-1月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023008','创新项目','国家级','无人驾驶控制系统','8218220120','S002','30000','01-5月 -23','30-4月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023009','创业项目','校级','高效能太阳能发电板','8218220125','S002','10000','01-7月 -23','30-6月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023010','创新项目','省级','智慧交通管理系统','8218220129','S002','18000','01-9月 -23','31-8月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023011','创新项目','校级','AI驱动的医学影像分析','8228220101','S003','7000','01-1月 -23','31-12月-23'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023012','创业项目','省级','工业机器人优化系统','8228220105','S003','13000','01-3月 -23','29-2月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023013','创新项目','国家级','深度学习与计算机视觉研究','8228220110','S003','28000','01-6月 -23','31-5月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023014','创业项目','校级','虚拟现实教学系统','8228220115','S003','9000','01-7月 -23','30-6月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023015','创新项目','省级','智慧医疗平台','8228220120','S003','16000','01-9月 -23','31-8月 -24'); INSERT INTO PROJECTS_110 VALUES ('CXCY2023075','创新项目','省级','智慧医疗平台','8228220120','S003','16000','01-9月 -23','31-8月 -24');
http://www.jsqmd.com/news/466551/

相关文章:

  • C++底层学习精进:模板进阶
  • 4.ChatGPT辅助产品数据分析
  • 分析2026年超声波切割机供应企业,常州中禹激光装备费用多少 - 工业品网
  • 【初学者入门C语言】之for循环语句
  • 基于Springboot的新疆特色文化在线教育平台推荐系(Springboot,vue,mysql,协同过滤算法,智能AI接口)
  • 南昌2026年全案设计装修公司排名,好用的品牌有哪些 - 工业设备
  • 2026年AI汽车发展的“中国方案”:从技术跟随到全球引领的范式革命
  • 这样使用雪花算法被客户喷了!
  • 大润发购物卡回收别乱选!这波操作让闲置卡秒变现金流 - 京顺回收
  • 【SSP之路-5-重要节点】LFU
  • PageHelper 解析及实现原理
  • 对比VBA学习Python,让办公更自动化!
  • 很多人卡在这一步:OpenClaw不会安装?这个一键版解决了
  • 【Linux】进程 PCB、task_struct、fork初识
  • 基于二进制的遗传算法的考虑排放目标和输电损耗的经济调度研究(Python代码实现)
  • 扫地机机器人研发岗深度解析与技术指南
  • 140个企业级实战场景剖析以及AI大模型项目实战
  • 函数式编程思想
  • 2026钻床市场热门:这些工厂钻床受追捧,目前优质的钻床品牌技术引领与行业解决方案解析 - 品牌推荐师
  • 汇源全屋定制作为全屋定制专业制造商,价格大概多少钱? - 工业推荐榜
  • 基于改进粒子群算法的含碳捕集微网多时间尺度低碳经济调度(Matlab代码实现)
  • Flutter 三方库 system_resources_2 的鸿蒙化适配指南 - 实时监控鸿蒙端侧 CPU 负载、内存占用与系统资源动态感知
  • 星焰家居这个不锈钢全屋定制厂商品牌靠不靠谱,值得推荐吗? - myqiye
  • 2026年热门的CNC 精密压铸加工公司推荐:医疗设备精密压铸加工/智能家居精密压铸加工采购指南厂家怎么选 - 行业平台推荐
  • # 发散创新:WebHID 在浏览器端实现外设通信的全新实践 在现代Web 开
  • 2026年评价高的储能弹簧工厂推荐:耐腐蚀弹簧/小家电电磁阀弹簧/高压直流继电器弹簧精选厂家推荐 - 行业平台推荐
  • Python开发英语记忆单词软件 - 优化
  • FFMpeg + WebSocket + JSMpeg 搭建低延迟视频系统(总览篇)
  • 2026年01月深圳CE:加速寿命试验/合规类/国内外认证/机构类/测试服务/温度老化试验/电子电气检测/腐蚀试验/选择指南 - 优质品牌商家
  • 2026国内小白纹绣培训重实操机构推荐榜:野生眉学校、零基础学纹眉、零基础小白、零基础纹眉学校、零结痂雾眉、韩式定妆学校选择指南 - 优质品牌商家