用MySQL实现发号器
浏览:3173次 出处信息
问题:用MySQL实现发号器功能,确保每次取到的ID号都是唯一的
实现:下面是一个大致的思路,抛个砖,欢迎回帖。
根据号段大小,决定是否分成多个表,每个表事先填充各个不同的号段。
每个应用端取号时,设置事务隔离级别为:REPEATABLE READ,并且采用下面的方式读取数据
以下是代码片段: SELECT `ID` FROM `ID_RANGE_XX` ORDER BY ID LIMIT 1 FOR UPDATE |
在上述情境中,只要选择某个ID号,那么其他终端也在读取该号时,会产生锁等待,而不会发生ID号被重用的情况。
考虑到并发的问题,建议增加分表数量,每次循环或随机从分表中读取数据,降低对单个表的并发请求。
建议继续学习:
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:通过PostgreSQL的源代码安装数据库
后一篇:(总结)mysql中对已存在的表做增/删/改列的相关操作 >>
文章信息
- 作者:yejr 来源: MySQL 中文网 -
- 标签: 发号器 唯一号
- 发布时间:2010-07-21 09:45:07
建议继续学习
近3天十大热文
- [729] WEB系统需要关注的一些点
- [237] 如何拿下简短的域名
- [20] 移动音乐产品梳理
- [15] Chrome开发者工具的小技巧
- [15] 豆瓣是啥?
- [13] Perl 的线程中的共享
- [13] 产品经理的取舍之道与抽象能力
- [12] iOS和Android设计规范备忘表
- [12] 内存的惰性初始化
- [12] 基于SSD的数据库性能优化