青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

一個反映DB2 游標的經(jīng)典問題

Posted on 2010-03-18 22:56 Prayer 閱讀(497) 評論(0)  編輯 收藏 引用 所屬分類: DB2

    本文中的存儲過程示例,預計的循環(huán)次數(shù)是yh表行數(shù),由于SELECT IID INTO PINT FROM YH WHERE 0=1;不返回任何行,所以at_end后會立刻等于1(只循環(huán)一次就退出)。
 

DECLARE  at_end  INT  DEFAULT  0; 
DECLARE PIID INTEGER DEFAULT 0 ;
DECLARE PINT INTEGER DEFAULT 0 ;
DECLARE  not_found  CONDITION  FOR  SQLSTATE  '02000';
--DECLARE PCOUNT INTEGER;
DECLARE  c1  CURSOR  FOR   
SELECT IID FROM YH; 
DECLARE  CONTINUE  HANDLER  FOR  not_found 
SET  at_end  1; 
OPEN  c1; 
SET PCOUNT=0;
ins_loop:
LOOP 
FETCH  c1  INTO  PIID; 
IF  at_end  <>0    THEN 
LEAVE  ins_loop; 
END  IF; 
SET PCOUNT=PCOUNT+1;
SELECT IID INTO PINT FROM YH WHERE 0=1;
END LOOP;

 

http://www.souzz.net/html/database/DB2/69884.html

 

CREATE PROCEDURE bump_salary_iftest (IN deptnumber SMALLINT)
LANGUAGE SQL
BEGIN
  DECLARE SQLSTATE CHAR(5);
  DECLARE v_salary DOUBLE;
  DECLARE v_years SMALLINT;
  DECLARE v_id SMALLINT;
  DECLARE at_end INT DEFAULT 0;
  DECLARE not_found CONDITION FOR SQLSTATE '02000';

  DECLARE C1 CURSOR FOR
    SELECT id, CAST(salary AS DOUBLE), years
    FROM staff;
  DECLARE CONTINUE HANDLER FOR not_found
    SET at_end = 1;

  OPEN C1;
  FETCH C1 INTO v_id, v_salary, v_years;
  WHILE at_end = 0 DO

      UPDATE staff
        SET salary = 2150 * v_years
        WHERE id = -1;

    FETCH C1 INTO v_id, v_salary, v_years;
  END WHILE;
  CLOSE C1;
END

請問,我想讓這個循環(huán)執(zhí)行完,但是由于SET salary = 2150 * v_years
        WHERE id = -1 更新的數(shù)據(jù)為0條,at_end變量就被置為1,從而導程序跳出循環(huán),我如何做,能夠及時更新數(shù)據(jù)為0行
,而循環(huán)還能繼續(xù)下去呢,請高手指點
                                                              


解決方案:

可以先計算循環(huán)次數(shù),根據(jù)這個數(shù)值進行循環(huán) :

CREATE  PROCEDURE  bump_salary_iftest(IN deptnumber SMALLINT,out iReturn int)
LANGUAGE  SQL
BEGIN
      DECLARE  SQLSTATE  CHAR(5);
      DECLARE  v_salary  DOUBLE;
      DECLARE  v_years  SMALLINT;
      DECLARE  v_id  SMALLINT;
      DECLARE  at_end  INT  DEFAULT  0;
      DECLARE  not_found  CONDITION  FOR  SQLSTATE  '02000';
     
      Declare  v_temp int;

      DECLARE  C1  CURSOR  FOR
          SELECT  id,  CAST(salary  AS  DOUBLE),  years
          FROM  staff;
      DECLARE  CONTINUE  HANDLER  FOR  not_found
          SET  at_end  1;
         
      -- get the loop number
  select count(*) into v_temp from staff;
  set iReturn =0;
      OPEN  C1;
      FETCH  C1  INTO  v_id,  v_salary,  v_years;
      WHILE  v_temp>0  DO
            -- out the iReturn to check the result
set iReturn =iReturn+1;
            UPDATE  staff
                  SET  salary  2150  v_years
                  WHERE  id  -1;
          FETCH  C1  INTO  v_id,  v_salary,  v_years;
          set v_temp = v_temp-1;
      END  WHILE;
      CLOSE  C1;
END@
 
 
http://topic.csdn.net/u/20071214/14/2c93b395-76c6-4a9d-b017-6733562edcfa.html

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美韩日一区| 最新国产乱人伦偷精品免费网站 | 免费观看一级特黄欧美大片| 这里只有精品视频| 亚洲精品视频二区| 亚洲国产精品高清久久久| 国产欧美日韩亚洲精品| 欧美午夜免费电影| 欧美日韩中文字幕在线视频| 欧美搞黄网站| 欧美精品一区在线| 久久一本综合频道| 久久嫩草精品久久久精品| 久久精品视频在线观看| 久久久久网站| 亚洲精品一区二区三区樱花| 亚洲二区免费| 欧美风情在线观看| 亚洲第一精品福利| 亚洲免费播放| 亚洲午夜影视影院在线观看| 亚洲欧美国产精品桃花| 亚洲第一页中文字幕| 亚洲高清一区二| 99精品国产热久久91蜜凸| 亚洲美女毛片| 中文欧美日韩| 久久国产精品99久久久久久老狼 | 久久午夜国产精品| 亚洲一区免费视频| 久久精品视频在线| 国产精品国产三级国产| 亚洲人成免费| 一区二区三区导航| 久久久噜噜噜久久人人看| 性色一区二区三区| 久久久久久噜噜噜久久久精品| 久久精品国产亚洲高清剧情介绍| 久久三级视频| 亚洲精品影视在线观看| 亚洲欧美日韩一区在线观看| 久久亚洲综合色| 99re6这里只有精品视频在线观看| 一本一本久久| 欧美一区二区在线观看| 欧美精品一区二区三区四区| 国产嫩草影院久久久久| 亚洲国产欧美日韩精品| 性欧美超级视频| 欧美国产日韩亚洲一区| 亚洲午夜久久久久久尤物| 一区二区三区四区五区在线| 欧美大片在线观看一区二区| 欧美一区视频在线| 国产三区精品| 欧美在线一二三区| 一区二区三区黄色| 欧美理论片在线观看| 亚洲六月丁香色婷婷综合久久| 欧美一区在线直播| 欧美一级二区| 国产日韩欧美综合一区| 久久激情五月丁香伊人| 一区二区三区偷拍| 国产精品二区二区三区| 亚洲一区二区三区涩| 日韩亚洲一区二区| 欧美少妇一区二区| 性8sex亚洲区入口| 亚洲一区日韩在线| 国产精品日韩欧美一区二区三区| 亚洲一区二区少妇| 亚洲无亚洲人成网站77777 | 久久阴道视频| 欧美一区二区三区久久精品茉莉花 | 国产精品爱啪在线线免费观看| 国产精品免费观看视频| 9l国产精品久久久久麻豆| 亚洲国产精品电影| 欧美激情久久久久久| 亚洲乱码国产乱码精品精98午夜 | 欧美日韩国产综合网| 亚洲国产婷婷| 亚洲丁香婷深爱综合| 欧美精品亚洲精品| 亚洲一区二区精品在线观看| 亚洲国内精品| 国产精品成人久久久久| 欧美一级电影久久| 久久精品99国产精品| 国内在线观看一区二区三区| 久久中文精品| 欧美国产综合视频| av不卡免费看| 亚洲在线视频一区| 精久久久久久| 亚洲精品日日夜夜| 国产农村妇女精品一区二区| 国产精品久久一卡二卡| 久久高清一区| 免费精品99久久国产综合精品| 亚洲裸体视频| 亚洲免费一在线| 在线国产精品播放| 一区二区三区免费观看| 狠狠色综合网| 日韩视频欧美视频| 伊人精品成人久久综合软件| 日韩视频一区二区在线观看 | 久久久久女教师免费一区| 99国产精品自拍| 久久aⅴ国产欧美74aaa| 在线综合欧美| 蜜臀99久久精品久久久久久软件| 亚洲午夜久久久久久久久电影院| 久久电影一区| 亚洲欧美在线另类| 免费在线看一区| 久久精品一区二区国产| 欧美激情视频给我| 久久久一区二区| 国产精品久久久久久久电影| 欧美国产免费| 国产亚洲综合精品| 中日韩视频在线观看| 亚洲天堂免费观看| 亚洲国产影院| 欧美专区在线| 午夜日韩在线| 欧美日韩一本到| 久久综合九色| 国产精品日日摸夜夜摸av| 亚洲美女视频| 1000部国产精品成人观看| 亚洲影院免费| 亚洲私人黄色宅男| 欧美日韩精品一区二区三区| 欧美不卡三区| 国产亚洲精品久久久久久| 亚洲一区二区三区777| 亚洲国产精品久久| 久久精精品视频| 99成人在线| 黄色成人在线| 一本色道**综合亚洲精品蜜桃冫| 久久久九九九九| 欧美中文在线字幕| 国产美女精品免费电影| 亚洲性线免费观看视频成熟| 欧美一级播放| 美女国内精品自产拍在线播放| 激情一区二区三区| 久久精品一区二区三区不卡牛牛 | 国产一区激情| 亚洲精品国精品久久99热| 亚洲精品看片| 欧美日韩成人综合天天影院| 亚洲人成久久| 亚洲免费一级电影| 国产精品久久久一本精品| 亚洲女性喷水在线观看一区| 欧美在线综合视频| 精品不卡视频| 你懂的亚洲视频| 亚洲美女视频在线免费观看| 亚洲欧美在线x视频| 国产在线精品二区| 免费亚洲一区二区| 日韩一区二区久久| 久久精品日韩欧美| 亚洲福利国产| 欧美 日韩 国产精品免费观看| 在线精品一区| 欧美日韩国产在线观看| 午夜欧美电影在线观看| 免费不卡亚洲欧美| 99天天综合性| 国产精品一区一区三区| 亚洲欧美日韩精品综合在线观看| 久久99伊人| 亚洲精品欧美| 国产美女一区二区| 欧美好骚综合网| 99国产精品久久久久久久久久| 欧美一区二区三区免费视频| 亚洲电影有码| 国产精品自拍一区| 欧美1级日本1级| 午夜国产欧美理论在线播放| 91久久精品国产91性色tv| 欧美亚洲三级| 日韩一二三在线视频播| 国产日韩欧美麻豆| 久久久久www| 中文精品视频一区二区在线观看| 国产拍揄自揄精品视频麻豆| 欧美电影资源| 久久久久久亚洲精品杨幂换脸| 亚洲精品午夜| 欧美成人日韩|