码迷,mamicode.com
首页 > 数据库 > 详细

mysql 自动定义序号:用来做"定单号"

时间:2015-05-26 16:38:52      阅读:484      评论:0      收藏:0      [点我收藏+]

标签:


自动定义序号:用来做"定单号"

总会有这样的需求,只是可能你没有遇到而已。我举个例子:若订单号的生成格式为“日期+序号”

(先不管需求是不是很傻逼),就像这样:2015052200001234,这个该如何处理呢?

若是有序列号,就比较好解决了。从00000001开始,到99999999,然后重置为一下序列,就OK啦。


-- 定义序列表

DROP TABLE IF EXISTS sequence;

CREATE TABLE sequence (

    name VARCHAR(50) NOT NULL,

    current_value INT NOT NULL,

    increment INT NOT NULL DEFAULT 1,

    PRIMARY KEY (name)

) ENGINE=InnoDB;

 

-- 获取当前序列号

DROP FUNCTION IF EXISTS currval;

DELIMITER $

CREATE FUNCTION currval (seq_name VARCHAR(50))

RETURNS INTEGER

CONTAINS SQL

BEGIN

    DECLARE value INTEGER;

    SET value = 0;

    SELECT current_value INTO value

    FROM sequence

    WHERE name = seq_name;

    RETURN value;

END$

DELIMITER ;

 

-- 获取下一个序列号

DROP FUNCTION IF EXISTS nextval;

DELIMITER $

CREATE FUNCTION nextval (seq_name VARCHAR(50))

RETURNS INTEGER

CONTAINS SQL

BEGIN

    UPDATE sequence SET current_value = current_value + increment

    WHERE name = seq_name;

    RETURN currval(seq_name);

END$

DELIMITER ;

 

-- 重设序列号

DROP FUNCTION IF EXISTS setval;

DELIMITER $

CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)

RETURNS INTEGER

CONTAINS SQL

BEGIN

    UPDATE sequence SET current_value = value

    WHERE name = seq_name;

    RETURN currval(seq_name);

    END$

DELIMITER ;

 

-- 初始化数据

INSERT INTO sequence VALUES (‘SAMPLE‘, 1, 1);

 

-- 测试

SELECT currval(‘SAMPLE‘);

SELECT nextval(‘SAMPLE‘);

SELECT nextval(‘SAMPLE‘);

SELECT setval(‘SAMPLE‘,150);

SELECT currval(‘SAMPLE‘);

SELECT nextval(‘SAMPLE‘);

SELECT nextval(‘SAMPLE‘);


mysql 自动定义序号:用来做"定单号"

标签:

原文地址:http://my.oschina.net/u/230843/blog/420098

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!