Skip to main content

SELECT DELETE STORED PROCEDURE

This stored procedure will help to select and delete records from table with passing variables.

create or replace PROCEDURE SP_DELETE_DATA (ID IN INTEGER,NAME IN VARCAHR2)
AS

CUR_01_F_COUNT NUMBER ;


CURSOR CUR_01 IS
SELECT COUNT(*)
FROM TABLE_NAME CF
WHERE ID         = ID
AND NAME=NAME;

BEGIN 


OPEN CUR_01;
FETCH CUR_01 INTO CUR_01_F_COUNT;
CLOSE CUR_01;
dbms_output.put_line(' COUNT FOR  IS :'||CUR_01_F_COUNT);

IF CUR_01_F_COUNT > 0 THEN

DELETE FROM TABLE_NAME WHERE ID=ID
AND NAME=NAME;

dbms_output.put_line('REMOVED COUNT IS :'||sql%ROWCOUNT);

IF SQL%ROWCOUNT>0 THEN
COMMIT;
END IF;
END IF;

Comments

Popular posts from this blog

Insert script with multiple cursors and condition check

DECLARE CURSOR C1 IS   SELECT ID FROM TABLE_NAME_1 WHERE COLUMN IN ('');   CURSOR C2     IS       SELECT ID FROM TABLE_NAME_2 WHERE COLUMN IN ('');              CURSOR C3 (CP_TABLE_01_ID NUMBER,CP_TABLE_02_ID NUMBER)         IS           SELECT COUNT(*) AS COUNT_UP           FROM TABLE_NAME_3           WHERE COLUMN_CONDITION_01=CP_TABLE_02_ID           AND COLUMN_CONDITION_02=CP_TABLE_01_ID; COUNT_UP NUMBER; BEGIN FOR R1 IN C1 LOOP     FOR R2 IN C2     LOOP          OPEN C3(R1.ID,R2.ID);        FETCH C3 INTO COUNT_UP;        CLOSE C3;               IF (COUNT_UP=0) THEN           INSERT           INTO TABL...

REF Cursor

REF CURSOR WILL BE DYNAMICALLY OPENS OR OPEN BASED ON A LOGIC. DECLARE TYPE C1 IS REF CURSOR ; CURSOR C IS SELECT * FROM DUAL; REF_CURSOR RC; BEGIN IF (TO_CHAR(SYSDATE, 'DD' ) = 30 ) THEN OPEN REF_CURSOR FOR 'SELECT * FROM TABLE1' ; ELSIF ( TO_CHAR(SYSDATE, 'DD' ) = 29 ) THEN OPEN REF_CURSOR FOR SELECT * FROM TABLE2; ELSE OPEN REF_CURSOR FOR SELECT * FROM DUAL; END IF ; OPEN C; END ;