Chinaunix

标题: 关于awk [打印本页]

作者: Eruza    时间: 2006-12-21 15:06
标题: 关于awk
小弟最近在学习awk时遇到一个难题
如何在shell中使用awk自定义的变量,有一个shell命令要在awk的循环中运行,需要awk的变量:
Result=`awk '{id[w++]=$1}{ip[x++]=$2}{db[y++]=$3}{pw[z++]=$4};END{
        function SQLSELECT(a,b,c,d){
#Get Hotel Id,Ip,Roomdatabase,Passwd,H_ser_pw Into sql.1 for test
Result=`/usr/src/freetds-0.63/src/apps/tsql -S $bb -U $DBUSER -P $dd << start
use $cc
go
select sum(1) as SUM from xxx where xxx='xxx'
go
start`
#DB sql end
        }
        for (i=0;i<NR;i++){
                SQLSELECT(id[i],ip[i],db[i],pw[i])
        }
}' bb=a dd=d cc=c sql.2`
echo $Result > sql.3

我是这样定义的"bb=a dd=d cc=c",是不是有问题?
作者: Eruza    时间: 2006-12-21 15:54
没人自己顶
作者: 一梦如是    时间: 2006-12-21 16:08
您干什么非要把一个脚本写成一句话呢?一步一步来不好么?
作者: Eruza    时间: 2006-12-21 23:57
我本也这样想过,不过那个tsql需要每次由awk去传给它不同的数据库地址来进行连接,不知有没有其他办法,
是否在awk脚本程序中不能使用shell的变量?




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2