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

首頁 > 數據庫 > Oracle > 正文

oracle(plsql)生成流水號

2024-08-29 13:57:58
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:


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;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东方市| 桦甸市| 莎车县| 新安县| 宣城市| 陆川县| 基隆市| 齐齐哈尔市| 博客| 平和县| 红河县| 盐池县| 酉阳| 鄂伦春自治旗| 龙州县| 江孜县| 璧山县| 尼木县| 永胜县| 汝城县| 微山县| 桦南县| 西乡县| 赞皇县| 忻城县| 澎湖县| 南康市| 南溪县| 基隆市| 高台县| 彩票| 乌兰浩特市| 漯河市| 隆子县| 六安市| 高邑县| 高邑县| 博客| 通州区| 额敏县| 高邑县|