免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3130 | 回复: 1
打印 上一主题 下一主题

[原创]利用协同进程,在db2执行SQL时显示经过的时间 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-05-19 09:49 |只看该作者 |倒序浏览
当db2对大数据量的表进行sql操作时通常都要花很长时间。这时如果什么都不显示的话会让人觉得等的很不耐烦,因此在db2执行sql的时候,画面上显示不断改变的经过时间,会不会让人稍微有点耐心呢?
下面的这段代码就是利用ksh的协同进程,来实现在db2执行SQL时显示不断改变的经过时间。


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

  8. #取得进程ID
  9. JOBPID=$!
  10. BASETIME=`date +"%H:%M:%S"`
  11. TIMEDISP="00:00:00"
  12. #显示经过时间
  13. echo " -->Elapsed: $TIMEDISP\c"
  14. while true
  15. do
  16.   sleep 1
  17.   if [ -z "`ps -ax | grep "^[[:space:]]*$JOBPID"`" ]
  18.   then
  19.     break
  20.   fi
  21.   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);}'`
  22.   echo "\b\b\b\b\b\b\b\b$TIMEDISP\c"
  23. done
  24. #取得SQL执行后的返回值
  25. wait $JOBPID
  26. RET=$?

  27. #让光标回到显示经过时间的行开始处
  28. 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"

  29. #返回值判断
  30. if [ $RET -eq 0 ]
  31. then
  32.   SDATA=""
  33.   LINECNT=0
  34.   BLANKFLG=0
  35.   #处理数据 注意:read的-p参数,从协同进程的标准输出中读取数据
  36.   while read -p SDATA
  37.   do
  38.     LINECNT=`expr $LINECNT + 1`
  39.     #1到3行是列名标题不是数据,因此不处理
  40.     if [ $LINECNT -ge 4 ]
  41.     then
  42.       STEMP=`echo "$SDATA" | awk '{if(NF>0)printf("AAA IS %s, BBB IS %s, CCC IS %s",$1,$2,$3);}'`
  43.       #空行不处理,但是空行后面的一行是SELECT的取得件数,因此设立flag
  44.       if [ -z "$STEMP" ]
  45.       then
  46.         BLANKFLG=1
  47.       elif [ $BLANKFLG -eq 1 ]
  48.       then
  49.         KENSU=`echo "$SDATA" | sed -n -e 's/[^0-9]*\([0-9]*\)[^0-9]*/\1/p'`
  50.         BLANKFLG=0
  51.       else
  52.         echo "$STEMP"
  53.       fi
  54.     fi
  55.   done
  56.   echo "The count of data is $KENSU ."
  57.   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);}'`
  58.   echo "Elapsed: $TIMEDISP\n"
  59. else
  60.   #SQL执行出错时显示db2返回的错误信息
  61.   while read -p SDATA
  62.   do
  63.     echo "$SDATA"
  64.   done
  65. fi

  66. #切断与数据库的连接
  67. db2 connect reset
  68. db2 terminate

  69. exit $RET
复制代码


这可是我原创的哦,大家多多支持哟。

论坛徽章:
0
2 [报告]
发表于 2005-05-19 10:02 |只看该作者

[原创]利用协同进程,在db2执行SQL时显示经过的时间

支持!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP