存储过程plsql_stored procedure_为业务系统所有业务表生成主键pk方式

create or replace procedure  p_get_maxid
(v_table_name IN VARCHAR2,v_maxid out varchar2)
  
IS
   ROWS      INTEGER;
     
BEGIN
   SELECT COUNT (*)
     INTO ROWS
     FROM SYSTEM_MAXID
    WHERE UPPER (table_name) = UPPER (v_table_name);
   IF ROWS = 0
   THEN
     v_maxid:=lpad(to_char(rows),16,'0');
     
      INSERT INTO SYSTEM_MAXID
                  (serial_no, table_name, maxid, id_len,
                   id_type, applier, apply_time
                  )
           VALUES (seq_maxid.NEXTVAL, UPPER (v_table_name), v_maxid, 20,
                   'number', 'aibo_User', SYSDATE
                  );
   ELSE
      SELECT maxid
        INTO rows
        FROM SYSTEM_MAXID
       WHERE UPPER (table_name) = UPPER (v_table_name);
  
   v_maxid := lpad(to_char(rows + 1),16,'0');
   UPDATE SYSTEM_MAXID
      SET maxid = v_maxid,
          apply_time = SYSDATE
    WHERE UPPER (table_name) = UPPER (v_table_name);
  END IF;
 
EXCEPTION
   WHEN NO_DATA_FOUND
   THEN
      dbms_output.put_line('no record');
END p_get_maxid;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9240380/viewspace-667565/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/9240380/viewspace-667565/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值