国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

oracle(plsql)生成流水號

2020-07-26 14:20:50
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

CREATE OR REPLACE FUNCTION fn_no_make(v_prefix     VARCHAR2,
                                      v_table_name VARCHAR2,
                                      v_number_col VARCHAR2)
 /*
  * v_prefix:     編碼前綴兩位
  * v_table_name:編碼所在表名
  * v_number_col:編碼所在列名
  */ 
  RETURN VARCHAR2 IS
  v_old_no   VARCHAR2(50); --原編碼
  v_new_no   VARCHAR2(50); --新編碼
  v_old_num  NUMBER;       --原編碼后三位編號
  v_new_num  VARCHAR2(10); --新編碼后三位編號
  v_date_no  VARCHAR2(10); --當前日期編號
  v_sql      VARCHAR2(4000);
BEGIN
  v_sql := 'SELECT MAX(' || v_number_col || ') FROM ' || v_table_name;
  EXECUTE IMMEDIATE v_sql INTO v_old_no;

  v_sql := 'SELECT TO_CHAR(SYSDATE,''YYYYMMDD'') FROM DUAL';
  EXECUTE IMMEDIATE v_sql INTO v_date_no;

  v_old_num := to_number(substr(v_old_no, 12, 3));
  v_new_num := lpad(to_char(v_old_num+1), 3, '0');

  IF v_old_no IS NULL OR substr(v_old_no, 3, 8) <> v_date_no THEN
    v_new_no := v_prefix || v_date_no || '-' || '001';
  ELSE
    v_new_no := v_prefix || v_date_no || '-' || v_new_num;
  END IF;

  RETURN v_new_no;
EXCEPTION
  WHEN OTHERS THEN
    dbms_output.put_line(SQLERRM);
END fn_no_make;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 扎赉特旗| 平顶山市| 扬中市| 府谷县| 融水| 庆阳市| 山东省| 卫辉市| 前郭尔| 阿尔山市| 讷河市| 肇源县| 汪清县| 宁安市| 长宁县| 秭归县| 封开县| 商都县| 大埔区| 永仁县| 依安县| 上饶县| 英吉沙县| 武隆县| 哈密市| 和龙市| 广灵县| 阳曲县| 平定县| 仲巴县| 沿河| 阿坝县| 揭阳市| 海宁市| 左云县| 陇南市| 河北区| 偏关县| 磐安县| 乌鲁木齐县| 休宁县|