• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            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
            久久婷婷五月综合97色一本一本| 婷婷综合久久中文字幕蜜桃三电影| 无码人妻久久久一区二区三区| 国内精品九九久久精品| 99精品国产99久久久久久97| 激情伊人五月天久久综合| 久久精品女人天堂AV麻| 亚洲AV无码久久寂寞少妇| 国产精品久久久99| 一本色道久久综合亚洲精品| 精品久久久久久国产免费了| 婷婷伊人久久大香线蕉AV | 国产成人无码精品久久久免费| 青青青青久久精品国产h久久精品五福影院1421 | 三级片免费观看久久| 狠狠干狠狠久久| 亚洲狠狠婷婷综合久久蜜芽| 日本国产精品久久| 草草久久久无码国产专区| 久久久无码精品亚洲日韩按摩 | 国产日产久久高清欧美一区| 久久亚洲中文字幕精品一区| 久久久WWW免费人成精品| 国产精品国色综合久久| 狠狠综合久久综合88亚洲| 日本久久中文字幕| 久久综合亚洲色HEZYO国产| 99久久精品免费看国产免费| 99久久国产综合精品麻豆| 欧洲成人午夜精品无码区久久| 中文成人久久久久影院免费观看| 久久99精品久久久久久秒播| 99久久精品国产一区二区| 国产一级做a爰片久久毛片| 国产婷婷成人久久Av免费高清| 久久久久久夜精品精品免费啦| 日产精品久久久久久久| 久久久久久久久无码精品亚洲日韩| 欧美噜噜久久久XXX| 91精品国产乱码久久久久久| 欧美久久综合性欧美|