Oracle 中循环遍历某张表,并对符合条件的进行Update操作

BEGIN

FOR L_RECORD IN (select RECORD_ID,CURR_PERIOD,PERIOD_START_DATE,(sysdate- PERIOD_START_DATE) diffTime,(P.PERIOD_END_DAY-P.PERIOD_BEGIN_DAY) periodDiffDay from cps_PATIENT_PATH_RECORD t1
inner join cps_treat_period p on p.Period_Id=t1.Curr_Period
where t1.path_state=1) 
LOOP
    IF (L_RECORD.DIFFTIME >=L_RECORD.periodDiffDay)    
      THEN 
        UPDATE cps_PATIENT_PATH_RECORD
           SET PERIOD_START_DATE=to_date(to_char(sysdate,'YYYY/MM/DD'),CURR_PERIOD =L_RECORD.CURR_PERIOD+1
         WHERE RECORD_ID=L_RECORD.RECORD_ID;
    END IF;
 END LOOP;
END;


格式:

FOR record IN (SELECT)

LOOP

  UPDATE T WHERE

END LOOP

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...