加入收藏 | 设为首页 | 会员中心 | 我要投稿 上海站长网 (https://www.021zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

mysql序列表,自增序列生成合同编号

发布时间:2022-12-10 13:34:37 所属栏目:MsSql教程 来源:转载
导读: Mysql实现自增序列
mysql自带了自增序列,为了方便通过数据库获取唯一的增长序列满足业务需求mssql 使用序列,模拟oracle序列完成序列获取方案;为了达到oracle序列的效果,在mysql创建函数

Mysql实现自增序列

mysql自带了自增序列,为了方便通过数据库获取唯一的增长序列满足业务需求mssql 使用序列,模拟oracle序列完成序列获取方案;为了达到oracle序列的效果,在mysql创建函数来完成模拟。

创建一个专门用来做序列的表:

create table sequence (         
seq_name        VARCHAR(50) NOT NULL, -- 序列名称         
current_val     INT         NOT NULL, -- 当前值         
increment_val   INT         NOT NULL    DEFAULT 1, -- 步长(跨度)  

1.创建函数---获取当前值(v_seq_name 参数值 代表序列名称)

create function currval(v_seq_name VARCHAR(50))     
returns integer    
begin        
    declare value integer;         
    set value = 0;         
    select current_val into value  from sequence where seq_name = v_seq_name;   
   return value;   
end;  

select currval('序列名称');

2.创建函数--获取下一个值(v_seq_name 参数值 代表序列名称)

create function nextval (v_seq_name VARCHAR(50))  
    returns integer  
begin  
    update sequence set current_val = current_val + increment_val  where seq_name = v_seq_name;  
    return currval(v_seq_name);  
end;  

最终使用方式:

select nextval('序列名称');

(编辑:上海站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!