用MySQL实现发号器
浏览:3178次 出处信息
问题:用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天十大热文
- [13] 手机客户端交互适配设计之我见
- [11] PDC 2010:C#与Visual Bas
- [11] 韩国实名制的破产
- [11] 谈谈Facebook的聊天系统架构
- [10] 一句话crontab实现防ssh暴力破解
- [10] 长假,回忆小时候的家庭教育点滴
- [10] Python连接 MySQL 数据库的超时问
- [10] Oracle bbed工具的编译
- [10] 四年前的今天,我开始找工作
- [9] 浅析韩国团购网站