Prayer

在一般中寻求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理
当db2对大数据量的表进行sql操作时通常都要花很长时间。这时如果什么都不显示的话会让人觉得等的很不耐烦,因此在db2执行sql的时候,画面上显示不断改变的经过时间,会不会让人稍微有点耐心呢?
下面的这段代码就是利用ksh的协同进程,来实现在db2执行SQL时显示不断改变的经过时间。

#连接数据库
db2 connect to mydb
#SQL文定义
SQL="SELECT AAA, BBB, CCC FROM MYTBL1"
echo "$SQL"
#执行SQL 注意:这里用到了协同进程
db2 "$SQL" |&

#取得进程ID
JOBPID=$!
BASETIME=`date +"%H:%M:%S"`
TIMEDISP="00:00:00"
#显示经过时间
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执行后的返回值
wait $JOBPID
RET=$?

#让光标回到显示经过时间的行开始处
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
  #处理数据 注意:read的-p参数,从协同进程的标准输出中读取数据
  while read -p SDATA
  do
    LINECNT=`expr $LINECNT + 1`
    #1到3行是列名标题不是数据,因此不处理
    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的取得件数,因此设立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执行出错时显示db2返回的错误信息
  while read -p SDATA
  do
    echo "$SDATA"
  done
fi

#切断与数据库的连接
db2 connect reset
db2 terminate

exit $RET

这可是我原创的哦,大家多多支持哟。
http://bbs.chinaunix.net/viewthread.php?tid=547413

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理