Chinaunix

标题: [代码]MySQL序列解决方案 [打印本页]

作者: mocow    时间: 2015-05-21 13:27
标题: [代码]MySQL序列解决方案
  1. -- 定义序列表
  2. DROP TABLE IF EXISTS sequence;
  3. CREATE TABLE sequence (
  4.     name VARCHAR(50) NOT NULL,
  5.     current_value INT NOT NULL,
  6.     increment INT NOT NULL DEFAULT 1,
  7.     PRIMARY KEY (name)
  8. ) ENGINE=InnoDB;

  9. -- 获取当前序列号
  10. DROP FUNCTION IF EXISTS currval;
  11. DELIMITER $
  12. CREATE FUNCTION currval (seq_name VARCHAR(50))
  13. RETURNS INTEGER
  14. CONTAINS SQL
  15. BEGIN
  16.     DECLARE value INTEGER;
  17.     SET value = 0;
  18.     SELECT current_value INTO value
  19.     FROM sequence
  20.     WHERE name = seq_name;
  21.     RETURN value;
  22. END$
  23. DELIMITER ;

  24. -- 获取下一个序列号
  25. DROP FUNCTION IF EXISTS nextval;
  26. DELIMITER $
  27. CREATE FUNCTION nextval (seq_name VARCHAR(50))
  28. RETURNS INTEGER
  29. CONTAINS SQL
  30. BEGIN
  31.     UPDATE sequence SET current_value = current_value + increment
  32.     WHERE name = seq_name;
  33.     RETURN currval(seq_name);
  34. END$
  35. DELIMITER ;

  36. -- 重设序列号
  37. DROP FUNCTION IF EXISTS setval;
  38. DELIMITER $
  39. CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
  40. RETURNS INTEGER
  41. CONTAINS SQL
  42. BEGIN
  43.     UPDATE sequence SET current_value = value
  44.     WHERE name = seq_name;
  45.     RETURN currval(seq_name);
  46.     END$
  47. DELIMITER ;

  48. -- 初始化数据
  49. INSERT INTO sequence VALUES ('SAMPLE', 1, 1);

  50. -- 测试
  51. SELECT currval('SAMPLE');
  52. SELECT nextval('SAMPLE');
  53. SELECT nextval('SAMPLE');
  54. SELECT setval('SAMPLE',150);
  55. SELECT currval('SAMPLE');
  56. SELECT nextval('SAMPLE');
  57. SELECT nextval('SAMPLE');
复制代码





欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2