當(dāng)db2對大數(shù)據(jù)量的表進(jìn)行sql操作時(shí)通常都要花很長時(shí)間。這時(shí)如果什么都不顯示的話會(huì)讓人覺得等的很不耐煩,因此在db2執(zhí)行sql的時(shí)候,畫面上顯示不斷改變的經(jīng)過時(shí)間,會(huì)不會(huì)讓人稍微有點(diǎn)耐心呢?
下面的這段代碼就是利用ksh的協(xié)同進(jìn)程,來實(shí)現(xiàn)在db2執(zhí)行SQL時(shí)顯示不斷改變的經(jīng)過時(shí)間。
#連接數(shù)據(jù)庫
db2 connect to mydb
#SQL文定義
SQL="SELECT AAA, BBB, CCC FROM MYTBL1"
echo "$SQL"
#執(zhí)行SQL 注意:這里用到了協(xié)同進(jìn)程
db2 "$SQL" |&
#取得進(jìn)程ID
JOBPID=$!
BASETIME=`date +"%H:%M:%S"`
TIMEDISP="00:00:00"
#顯示經(jīng)過時(shí)間
echo " -->Elapsed: $TIMEDISP\c"
while true
do
sleep 1
if [ -z "`ps -ax | grep "^[[:space:]]*$JOBPID"`" ]
then
break
fi
TIMEDISP=`date +"$BASETIME:%H:%M:%S" | awk -F":" '{hh=$4-$1;mm=$5-$2;ss=$6-$3;if(ss<0){ss=60+ss;mm--;};if(mm<0){mm=60+mm;hh--;};if(hh<0)hh=24+hh;printf("%02d:%02d:%02d",hh,mm,ss);}'`
echo "\b\b\b\b\b\b\b\b$TIMEDISP\c"
done
#取得SQL執(zhí)行后的返回值
wait $JOBPID
RET=$?
#讓光標(biāo)回到顯示經(jīng)過時(shí)間的行開始處
echo "\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\c"
#返回值判斷
if [ $RET -eq 0 ]
then
SDATA=""
LINECNT=0
BLANKFLG=0
#處理數(shù)據(jù) 注意:read的-p參數(shù),從協(xié)同進(jìn)程的標(biāo)準(zhǔn)輸出中讀取數(shù)據(jù)
while read -p SDATA
do
LINECNT=`expr $LINECNT + 1`
#1到3行是列名標(biāo)題不是數(shù)據(jù),因此不處理
if [ $LINECNT -ge 4 ]
then
STEMP=`echo "$SDATA" | awk '{if(NF>0)printf("AAA IS %s, BBB IS %s, CCC IS %s",$1,$2,$3);}'`
#空行不處理,但是空行后面的一行是SELECT的取得件數(shù),因此設(shè)立flag
if [ -z "$STEMP" ]
then
BLANKFLG=1
elif [ $BLANKFLG -eq 1 ]
then
KENSU=`echo "$SDATA" | sed -n -e 's/[^0-9]*\([0-9]*\)[^0-9]*/\1/p'`
BLANKFLG=0
else
echo "$STEMP"
fi
fi
done
echo "The count of data is $KENSU ."
TIMEDISP=`date +"$BASETIME:%H:%M:%S" | awk -F":" '{hh=$4-$1;mm=$5-$2;ss=$6-$3;if(ss<0){ss=60+ss;mm--;};if(mm<0){mm=60+mm;hh--;};if(hh<0)hh=24+hh;printf("%02d:%02d:%02d",hh,mm,ss);}'`
echo "Elapsed: $TIMEDISP\n"
else
#SQL執(zhí)行出錯(cuò)時(shí)顯示db2返回的錯(cuò)誤信息
while read -p SDATA
do
echo "$SDATA"
done
fi
#切斷與數(shù)據(jù)庫的連接
db2 connect reset
db2 terminate
exit $RET