作者:iamlaosong

我们常常在shell脚本程序中用<<EOF重定向输入。将我们输入的命令字符串作为一个运行程序的输入,这样,我们就不须要在那个程序环境中手工输入命令,以便自己主动运行我们须要的功能,比如:

sqlplus emssxjk/emssxjk <<EOF
select count(*) from sncn_yxyj where create_date like sysdate;
EOF


当中的SQL语句相当于在sqlplus程序环境中输入的。这样输入的内容夹在两个EOF之间,可长可短,EOF也能够换成其它随意的字符。大写和小写不论。仅仅要成对出现就可以,比如:

sqlplus emssxjk/emssxjk <<STD
select count(*) from sncn_yxyj where create_date like sysdate;
STD

当然这个标志性字符不能用保留字,最经常使用的还是EOF。

须要注意的是。第一个EOF必须以重定向字符<<開始。第二个EOF必须顶格写,否则会报错。

再看一个自己主动FTP的样例:

#ftp data to 10.178.37.244
rq=`date +%Y%m%d`
cd /data/product/song
ftp -i -n <<!
open 10.178.37.244 
user oracle post 
cd ems 
bin
put ${rq}.dat 
bye
!


posted on 2017-08-12 10:09  yutingliuyl  阅读(1069)  评论(0编辑  收藏  举报