oracle(plsql)生成流水号

 更新时间:2014年03月29日 10:22:31   作者:  
这篇文章主要介绍了oracle(plsql)生成流水号,需要的朋友可以参考下

复制代码 代码如下:

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;

相关文章

  • Oracle下的Java分页功能_动力节点Java学院整理

    Oracle下的Java分页功能_动力节点Java学院整理

    分页的时候返回的不仅包括查询的结果集(List),而且还包括总的页数(pageNum)、当前第几页(pageNo)等等信息,所以我们封装一个查询结果PageModel类,具体实现代码,大家参考下本文
    2017-08-08
  • sql – Oracle中匿名TABLE/VARRAY类型示例详解

    sql – Oracle中匿名TABLE/VARRAY类型示例详解

    这篇文章主要给大家介绍了关于Oracle中匿名TABLE/VARRAY类型的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用oracle具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • oracle 12c因误删pdb数据文件导致整个数据库打不开的解决方法

    oracle 12c因误删pdb数据文件导致整个数据库打不开的解决方法

    这篇文章主要给大家介绍了关于oracle 12c因误删pdb数据文件导致整个数据库打不开问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。
    2017-10-10
  • [Oracle] CPU/PSU补丁安装详细教程

    [Oracle] CPU/PSU补丁安装详细教程

    Oracle CPU的全称是Critical Patch Update, Oracle对于其产品每个季度发行一次安全补丁包,通常是为了修复产品中的安全隐患,以下是对CPU/PSU补丁安装的具体操作步骤进行了详细的分析介绍,需要的朋友可以参考
    2013-07-07
  • Oracle锁表问题的解决方法

    Oracle锁表问题的解决方法

    在实际工作中,并发量比较大的项目,经常会出现锁表的问题,下面我将复现这个问题,并给出解决方法,文中通过代码示例和图文介绍的非常详细,需要的朋友可以参考下
    2024-04-04
  • oracle与mysql的视频教程下载地址分享

    oracle与mysql的视频教程下载地址分享

    这是某培训机构的oracle跟mysql视频教程,现在分享给大家,想要学习mysql和oracle的同学不要错过哦
    2013-03-03
  • Oracle数据库常见字段类型大全以及超详细解析

    Oracle数据库常见字段类型大全以及超详细解析

    在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,这篇文章主要介绍了Oracle数据库常见字段类型大全以及超详细解析,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-04-04
  • oracle常用数据类型说明

    oracle常用数据类型说明

    这篇文章主要介绍了oracle常用数据类型说明,需要的朋友可以参考下
    2014-02-02
  • oracle连接ODBC sqlserver数据源的详细步骤

    oracle连接ODBC sqlserver数据源的详细步骤

    这篇文章主要介绍了oracle连接sqlserver数据源ODBC的详细步骤,本文分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • Linux 创建oracle数据库的详细过程

    Linux 创建oracle数据库的详细过程

    这篇文章主要介绍了Linux 创建oracle数据库,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03

最新评论