shell获取sqlplus变量_[20190126]从sqlplus执行结果返回bash shell变量.txt

本文介绍了在Bash Shell脚本中如何正确获取SQL*Plus查询结果并将其作为变量使用。在示例中,作者通过调整SQL*Plus的设置避免了因换行符导致的输出问题,并探讨了Shell变量处理回车等特殊字符的方式。通过对比不同的脚本写法,阐述了如何确保变量值正确显示。
摘要由CSDN通过智能技术生成

[20190126]从sqlplus执行结果返回bash shell变量.txt

--//前几天写bash shell脚本遇到的问题,自己以前忽略这个问题,通过例子说明。

$ cat d.sh

# this is a test

file_name=`sqlplus -S sys/a as sysdba <

set head off

select name c100  from v\\$dbfile where file#=11;

quit

EOF

`

echo 1111 $file_name 2222

echo "1111 $file_name 2222"

--//执行如下:

$ . d.sh

1111 D:\APP\ORACLE\ORADATA\TEST\TEST01P\USERS01.DBF 2222

1111

D:\APP\ORACLE\ORADATA\TEST\TEST01P\USERS01.DBF 2222

--//在调试时遇到的问题,按照道理感觉2者的显示应该一样,实际上第2次执行(带引号)的部分,明显$file_name里面含有1个回车。

--//有点不理解的地方是为什么第1次执行可以在一行显示。

--//改成如下,两者就显示一样了:

# this is a test

file_name=`sqlplus -S sys/a as sysdba <

set head off pagesize 0 feedback off verify off  echo off

select name c100  from

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值