📖SPOOL导出指定格式的Oracle数据文件

发布: 2024-03-08
热度: 15
趋势: 15
权重: 0
🎯

为了方便数据的处理,或者本身有特殊的数据格式要求,我们可以使用SPOOL命令导出Oracle数据库数据数据文件,并指定格式,高效且强大...

数据文件诉求

如今,自动化是大家越来越关注的方向,很多任务更加迫切需要一键/小白化。

在对于 Oracle 数据库数据的处理,不能始终死板的使用 import 语句来导出数据。

.dmp 文件局限性太大(尤其是不便于处理)。

在 SHELL 脚本中,.dmp 文件处理起来非常麻烦,容错率极差。

自动化脚本中,对于规整的指定格式的文本处理起来更加得心应手,不容易出错。

米虫在本文中以导出数据库表记录,逗号隔开字段内容为例,写一个脚本实例。

配置信息

编写数据导出主要用到 sqlplus 客户端命令、 spool 命令和 EOF 命令。

spool 可以设置大量的格式化配置。

# 基本配置
dbName=mebugs
dbPW=password
old_db_ip_port_id=127.0.0.1:1536/ora11g
# 导出的数据文件
dataFile=data/user_mebugs_info.txt
# 数据库连接命令
sqlplus -s $dbName/$dbPW@//$old_db_ip_port_id
# SPOOL的指定文件 
spool $dataFile  

由于 EOF 语句中不支持加批注,所有配置项在此处说明

  • SET echo OFF 不输出结果至界面
  • SET feedback OFF 不输出执行反馈(如:8 rows selected.)
  • SET newpage NONE 不输出分页的空白行
  • SET pagesize 0 不设置分页
  • SET linesize 5000 每行最大长度
  • SET verify OFF 不输出确认信息
  • SET term OFF 不输出大表数据界面
  • SET trims ON 每行多余的空格去掉
  • SET heading OFF 不输出表头
  • SET trimspool ON 文件尾部去空格
  • SET trimout ON 控制台尾部去空格
  • SET timing OFF 不显示执行语句所用的时间

所关闭设置是为了导出特定格式的数据文件更纯粹,跟便于格式化处理。

具体配置按照个人的需求去配置。

导出的数据格式通过 SQL 多字段拼接为一个字段,可以自定义。

脚本样例

# 基本配置
dbName=mebugs
dbPW=password
old_db_ip_port_id=127.0.0.1:1536/ora11g
# 导出的数据文件
dataFile=data/user_mebugs_info.txt
# 开始导出
sqlplus -s $dbName/$dbPW@//$old_db_ip_port_id > /dev/null<<EOF
spool $dataFile
SET echo OFF
SET feedback OFF
SET newpage NONE
SET pagesize 0
SET linesize 5000
SET verify OFF
SET term OFF
SET trims ON
SET heading OFF
SET trimspool ON
SET trimout ON
SET timing OFF
select rtrim(COLUMN_1,chr(10))||','||rtrim(COLUMN_2,chr(10))||','||rtrim(COLUMN_3,chr(10))||','||rtrim(COLUMN_4,chr(10)) from mebugs_data;
spool OFF
exit
EOF

关于 EOF 本站有文章介绍过,一个简单的支行输出指令的语法,感兴趣可以看看。

当前文章暂无讨论,留下脚印吧!
大纲
  • 数据文件诉求
  • 配置信息
  • 脚本样例
提交成功,请等待审核通过后全面展示!

发表评论

昵称
邮箱
链接
签名
评论

温馨提示:系统将通过浏览器临时记忆您曾经填写的个人信息且支持修改,评论提交后仅自己可见,内容需要经过审核后方可全面展示。

选择头像