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

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


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


$ cat d.sh

# this is a test


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

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 <<EOF

set head off pagesize 0 feedback off verify off  echo 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


--//我看了以前的脚本有一些都是第一种写法的,居然没有报错。bash shell在处理变量值里面带有回车之类字符时

--//如果不使用引号引起来,删除回车之类字符输出,而带引号原样输出。

--//可以通过如下例子说明:

$ a=$(cat d.sh)


$ echo $a

# this is a test file_name=`sqlplus -S sys/a as sysdba <<EOF set head off pagesize 0 feedback off...

--//变成一行。


$ echo "$a"

# this is a test


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

set head off pagesize 0 feedback off verify off  echo off

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

quit

EOF

`

echo 1111 $file_name 2222

echo "1111 $file_name 2222"




来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/267265/viewspace-2564926/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/267265/viewspace-2564926/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值