Oracle过程更改多列中的日期

Oracle过程更改多列中的日期,oracle,plsql,procedure,Oracle,Plsql,Procedure,尝试创建一个在结束日期小于sysdate时更改日期的过程,但它会更改所有日期,因此代码如下: CREATE OR REPLACE PROCEDURE CHANGE_DATES as BEGIN FOR rec IN (SELECT start_period_date,end_period_date FROM mytable) LOOP DBMS_OUTPUT.PUT_LINE('Old Date:' || rec.start_period_date ||' ' || rec

尝试创建一个在结束日期小于sysdate时更改日期的过程,但它会更改所有日期,因此代码如下:

CREATE OR REPLACE PROCEDURE CHANGE_DATES 
as 

BEGIN
    FOR rec IN (SELECT start_period_date,end_period_date FROM mytable) LOOP
    DBMS_OUTPUT.PUT_LINE('Old Date:' || rec.start_period_date ||' ' || rec.end_period_date);
    IF rec.end_period_date < sysdate THEN
        update mytable set start_period_date = sysdate;
        update mytable set end_period_date = sysdate + 6;
        commit;
        --DBMS_OUTPUT.PUT_LINE('New Date:' || begin_date ||' ' ||end_date);
    end if;
END LOOP;
END;
您需要一个WHERE子句,可以在一个UPDATE语句中完成所有操作:

Oracle 11g R2架构设置:

问题2:

:


你听说过“WHERE”条款吗?update语句会显式更新每条记录。您需要一个游标并使用WHERE CURRENT OF或选择rowid并在WHERE子句中引用它。这真的很有帮助。
CREATE TABLE mytable ( start_period_date, end_period_date ) AS
SELECT DATE '2018-01-01', DATE '2018-01-02' FROM DUAL
/

CREATE OR REPLACE PROCEDURE CHANGE_DATES 
AS
  start_dates SYS.ODCIDATELIST;
  end_dates   SYS.ODCIDATELIST;
BEGIN
  UPDATE ( SELECT m.*,
                  ( SELECT m.start_period_date FROM DUAL ) AS old_start_date,
                  ( SELECT m.end_period_date   FROM DUAL ) AS old_end_date
           FROM mytable m )
  SET   start_period_date = SYSDATE,
        end_period_date   = SYSDATE + INTERVAL '6' DAY
  WHERE end_period_date   < SYSDATE
  RETURNING old_start_date, old_end_date
  BULK COLLECT INTO start_dates, end_dates;

  FOR i IN 1 .. start_dates.COUNT LOOP
    DBMS_OUTPUT.PUT_LINE( 'Old Date:' || start_dates(i) ||' ' || end_dates(i) );
  END LOOP;

  -- Do not COMMIT in the procedure, COMMIT in the calling scope.
END;
/
BEGIN
  CHANGE_DATES;
  COMMIT;
END;
SELECT * FROM mytable
|    START_PERIOD_DATE |      END_PERIOD_DATE |
|----------------------|----------------------|
| 2018-05-21T09:06:05Z | 2018-05-27T09:06:05Z |