最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql如何设置自动增长序列sequence(一)

来源:动视网 责编:小采 时间:2020-11-09 08:30:01
文档

mysql如何设置自动增长序列sequence(一)

mysql如何设置自动增长序列sequence(一):背景:由于项目需要,必须用mysql设置主键自增长,而且想用字符串的。经过上网查找并且实验,终于做出了一套方案。现在就共享给大家! 解决思路:由于mysql不带sequence,所以要手写的,创建一张储存sequence的表(tb_sequence),然后手动插入一条数据
推荐度:
导读mysql如何设置自动增长序列sequence(一):背景:由于项目需要,必须用mysql设置主键自增长,而且想用字符串的。经过上网查找并且实验,终于做出了一套方案。现在就共享给大家! 解决思路:由于mysql不带sequence,所以要手写的,创建一张储存sequence的表(tb_sequence),然后手动插入一条数据


背景:由于项目需要,必须用mysql设置主键自增长,而且想用字符串的。经过上网查找并且实验,终于做出了一套方案。现在就共享给大家! 解决思路:由于mysql不带sequence,所以要手写的,创建一张储存sequence的表(tb_sequence),然后手动插入一条数据 ,最后

背景:由于项目需要,必须用mysql设置主键自增长,而且想用字符串的。经过上网查找并且实验,终于做出了一套方案。现在就共享给大家!


解决思路:由于mysql不带sequence,所以要手写的,创建一张储存sequence的表(tb_sequence),然后手动插入一条数据 ,最后自定义一个函数来处理要增长的值。


一起做吧:

1、创建表tb_sequence,用来存放sequence值:

[sql] view plaincopyprint?

  1. create table tb_sequence(name varchar(50) not null,current_value int not null,_increment int not null default 1, primary key(name));


2、手动插入数据:

[sql] view plaincopyprint?

  1. insert into tb_sequence values('userid',100,2);


3、定义函数 _nextval:

[sql] view plaincopyprint?

  1. DELIMITER //
  2. create function _nextval(n varchar(50)) returns integer
  3. begin
  4. declare _cur int;
  5. set _cur=(select current_value from tb_sequence where name= n);
  6. update tb_sequence
  7. set current_value = _cur + _increment
  8. where name=n ;
  9. return _cur;
  10. end;
  11. //


说明:delimiter // ---->定义语句结束符。其他的代码 自己看吧。

4、恢复默认的语句结束符:(可以省略但是结束符必须用// ,为了方便还是设置回来。)

[sql] view plaincopyprint?

  1. DELIMITER ;


5、检验结果

多次执行以下语句:

[sql] view plaincopyprint?

  1. select _nextval('userid');


结果显示:

[sql] view plaincopyprint?

  1. mysql> select _nextval('userid');
  2. +--------------------+
  3. | _nextval('userid') |
  4. +--------------------+
  5. | 102 |
  6. +--------------------+
  7. 1 row in set (0.00 sec)
  8. mysql> select _nextval('userid');
  9. +--------------------+
  10. | _nextval('userid') |
  11. +--------------------+
  12. | 104 |
  13. +--------------------+
  14. 1 row in set (0.00 sec)
  15. mysql> select _nextval('userid');
  16. +--------------------+
  17. | _nextval('userid') |
  18. +--------------------+
  19. | 106 |
  20. +--------------------+
  21. 1 row in set (0.00 sec)


6、实验结束。

文档

mysql如何设置自动增长序列sequence(一)

mysql如何设置自动增长序列sequence(一):背景:由于项目需要,必须用mysql设置主键自增长,而且想用字符串的。经过上网查找并且实验,终于做出了一套方案。现在就共享给大家! 解决思路:由于mysql不带sequence,所以要手写的,创建一张储存sequence的表(tb_sequence),然后手动插入一条数据
推荐度:
标签: 设置 自动 如何
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top