oracle生成动态前缀且自增号码的函数分享

 更新时间:2014年04月23日 15:36:42   作者:  
这篇文章主要介绍了oracle生成动态前缀且自增号码的函数,需要的朋友可以参考下

复制代码 代码如下:

create or replace

Function GetInvitationNO(prev varchar2, num1 varchar2, num2 varchar2, sessionSetting varchar2)

Return Varchar2

Authid Current_User Is PRAGMA AUTONOMOUS_TRANSACTION;-- 需要使用“Current_User”的权限防止无法运行“Execute Immediate”命令 & “PRAGMA AUTONOMOUS_TRANSACTION”自制事务防止DML无法DDL的问题

Totalprev Varchar2(50);

Hassequences Number;

ReNO varchar2(50);

Begin

-- 号码的前缀

Totalprev := Prev || Num1 || Num2 || Sessionsetting;

-- 创建序列

Select Count(*) Into Hassequences From User_Sequences Where Sequence_Name=Totalprev;

If Hassequences <> 1 Then

Execute Immediate 'Create Sequence '||Totalprev||' Increment By 1 Start With 1 maxvalue 9999999 Nocycle';

End If;

-- 通过动态的序列名取序列值,把获取的序列值转换为7位长度的字符串,长度不足用“0”填充 

Execute Immediate 'Select '''|| Totalprev ||''' || to_char('||Totalprev||'.Nextval,''FM0000000'') From Dual' into ReNO;

-- to_char()中FM后跟的0代表了数字的位数,不足的用“0”填充;加上“FM”可以避免空格的出现,前面的空格是为符号位保留的,如果是对负数使用to_char,则空格部分是用来显示-的,因为是正数,所以不显示+,而是以空格代替

Return ReNO;

end;

测试

复制代码 代码如下:

Select GetInvitationNO('p', '1', '01', '114') From dual
-- Dual 是 Oracle中的一个实际存在的表,任何用户均可读取,常用在没有目标表的select语句块中

相关文章

  • 六分钟学会创建Oracle表空间的实现步骤

    六分钟学会创建Oracle表空间的实现步骤

    这里介绍创建Oracle表空间的步骤,首先查询空闲空间、增加Oracle表空间、修改文件大小语句如下、创建Oracle表空间,最后更改自动扩展属性
    2013-06-06
  • oracle中decode函数的使用方法示例

    oracle中decode函数的使用方法示例

    这篇文章主要介绍了oracle中decode函数的使用方法示例,还是比较不错的,这里分享给大家,供需要的朋友参考。
    2017-11-11
  • oracle分区索引的失效和重建代码示例

    oracle分区索引的失效和重建代码示例

    这篇文章主要介绍了oracle分区的失效和重建代码示例,小编觉得挺不错的,这里分享给大家,供需要的朋友参考。
    2017-10-10
  • Oracle报错记录被另外一个用户锁定的解决方案

    Oracle报错记录被另外一个用户锁定的解决方案

    这篇文章主要介绍了Oracle报错记录被另外一个用户锁定的解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • 解决Oracle DISTINCT 报错 inconsistent datatypes: expected - got CLOB(数据类型不一致: 应为 -, 但却获得 CLOB)的问题

    解决Oracle DISTINCT 报错 inconsistent datatypes: expected 

    这篇文章主要介绍了Oracle DISTINCT报错inconsistent datatypes:expected-got CLOB(数据类型不一致: 应为-,但却获得 CLOB),本文给大家分享三种解决方案,需要的朋友可以参考下
    2023-07-07
  • oracle 时间格式的调整

    oracle 时间格式的调整

    oracle下中文日期和英文日期的转换!
    2009-05-05
  • Oracle层次查询和with函数的使用示例

    Oracle层次查询和with函数的使用示例

    下面我跟大家分享下我的心得,也就是基于这种设计怎么做数形图,简单的做法就是查询出一个list集合就可以,要怎么办呢先来看下我的数据表
    2013-07-07
  • Oracle创建定时任务的方法步骤

    Oracle创建定时任务的方法步骤

    在日常的数据库管理中,经常会遇到需要定期执行某个任务的需求,本文主要介绍了Oracle创建定时任务的方法步骤,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • Oracle表空间数据文件移动的方法

    Oracle表空间数据文件移动的方法

    最近接了个项目,遇到这样的问题,需要实现把用户表空间中的数据文件从某一个路径下移动到另一个路径下,实现过程说简单不简单,说复杂不复杂,下面小编给大家分享我的解决办法,对oracle表空间数据文件相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • Oracle在PL/SQL中嵌入SQL语句

    Oracle在PL/SQL中嵌入SQL语句

    这篇文章介绍了Oracle在PL/SQL中嵌入SQL语句的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05

最新评论