oracle存储过程记录

 1 CREATE OR REPLACE PROCEDURE PROC_OPR_NAME
 2 (
 3         AA   IN VARCHAR DEFAULT NULL, 
 4         BB   IN VARCHAR DEFAULT NULL,
 5         CC   IN VARCHAR DEFAULT NULL, 
 6 ) AS
 7         V_VAL     VARCHAR2(40);
 8         V_SQL     VARCHAR2(1000);
 9         VV_VAL    VARCHAR2(40);
10         VV_SQL    VARCHAR2(1000);
11         V_UUID    VARCHAR2(40); 
12       CURSOR VV_LIST is SELECT * from TABLE T where T.COLUMN = '' AND T.COLUMN = AA  AND T.COLUMN IS NULL; --定义游标(集合)
13 
14 BEGIN
15 
16         IF CC is NULL THEN
17         RETURN;
18     END IF;
19 
20     V_SQL :='SELECT COLUMN_NAME FROM TABLE'||AA||' WHERE COLUMN_NAME ='''||BB||'''';
21     if BB =15900 then
22       V_SQL :='select '' from dual';
23     end if;
24     EXECUTE IMMEDIATE V_SQL into V_VAL;
25     
26     VV_SQL := 'SELECT MAX(COLUMN_NAME) FROM TABLE WHERE COLUMN_NAME=:1 AND COLUMN_NAME=:2 AND COLUMN_NAME=:3 AND COLUMN_NAME=:4';
27     EXECUTE IMMEDIATE VV_SQL
28         INTO VV_VAL
29         USING AA, 333, 666, 888;
30     
31         if CC =123456 then    
32 
33             FOR VALUE IN VV_LIST LOOP
34       
35           V_UUID := RAWTOHEX(sys_guid());
36                 
37               INSERT INTO TABLE(COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN, COLUMN) VALUES (V_UUID, '111', '111', '111', AA, VALUE.COLUMN_NAME, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
38             end loop;
39         end if;
40 END;

 

posted @ 2022-03-26 11:18  宋宋宋哥  阅读(119)  评论(0编辑  收藏  举报