免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4410 | 回复: 0
打印 上一主题 下一主题

[代码]MySQL序列解决方案 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-05-21 13:27 |只看该作者 |倒序浏览
  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');
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP