为了方便数据的处理,或者本身有特殊的数据格式要求,我们可以使用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 语句中不支持加批注,所有配置项在此处说明
所关闭设置是为了导出特定格式的数据文件更纯粹,跟便于格式化处理。
具体配置按照个人的需求去配置。
导出的数据格式通过 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 本站有文章介绍过,一个简单的支行输出指令的语法,感兴趣可以看看。
温馨提示:系统将通过浏览器临时记忆您曾经填写的个人信息且支持修改,评论提交后仅自己可见,内容需要经过审核后方可全面展示。