下面是两个类似的代码,为什么第一个可以工作,而第二个却不行?谁能解释一下圆括号后面的大括号的用法吗?
$ vi varoutput.bt
query_td () {
bteq << EOBTQ |grep '^>' |sed -e "s/^>//"
.LOGON TDPROD/userid,pass;
select top 3 '>'||t.cal_dt from rldmprod_v.cal_dt t where t.cal_dt = current_date;
.LOGOFF;
.QUIT;
EOBTQ
}
var=$(query_td)
echo $var
$ ksh varoutput.bt
2017/05/14
$ vi testoutput4.bt
testabcd=$(bteq <<EOF |grep '^>' |sed -e "s/^>//"
.LOGON TDPROD/userid,pass;
select top 3 '>'||t.cal_dt from rldmprod_v.cal_dt t where t.cal_dt = current_date;
.LOGOFF;
.QUIT;
EOF)
var=$testabcd
echo $var
$ ksh testoutput4.bt
*** Failure 5628 Column > not found in rldmprod_v.t.
Statement# 1, Info =0
答案1
内联块末尾的终止符(EOF
在您的情况下)必须是该行中唯一的字符串。你的脚本应该以这种方式重写:
testabcd=$(bteq <<EOF |grep '^>' |sed -e "s/^>//"
.LOGON TDPROD/userid,pass;
select top 3 '>'||t.cal_dt from rldmprod_v.cal_dt t where t.cal_dt = current_date;
.LOGOFF;
.QUIT;
EOF
)
var=$testabcd
echo $var