关于 mysql 并发查询的问题

2016-08-15 18:28:33 +08:00
 dai269619118

系统插入数据的时候 会给数据一个 order_number 字段来保存这个订单的编号

编号是自增的 1 , 2 , 3 , 4 这样自增

每插入一个订单都需要查询出最新插入订单,然后获取这个 order_number 在这个基础上加上 1

如果同一个时间插入几条数据的时候, order_number 字段会出现重复。

麻烦大家给个解决思路。

3534 次点击
所在节点    程序员
16 条回复
kevin1852
2016-08-15 18:40:58 +08:00
建表的时候建成自增字段,自己自增干嘛?
dear123
2016-08-15 18:47:12 +08:00
1# 说的对
gdsing
2016-08-15 19:23:39 +08:00
有自增字段放着不用,这不是没事找事做吗?
0915240
2016-08-15 19:40:51 +08:00
+1 楼 自增字段
kisssu
2016-08-15 19:44:27 +08:00
加唯一索引,主键和 order number 建立唯一索引
awanabe
2016-08-15 21:34:44 +08:00
做个 seq 序号生成器好了, 如果是分布式的不能做自增主键的话
murmur
2016-08-15 22:09:41 +08:00
每天都是从零开始 这点如果不允许用 mysql 自增或者 oracle 的序列的话 去干死写需求的
订单号写成 20160815xxxxxxx 不就完了 非得从 1 开始?
murmur
2016-08-15 22:13:16 +08:00
有点看错了
( 1 )订单号是不是必须从 1 开始 不是的话就用一个自增序列 mod 一个大数就可以了 需求什么的 编号什么的是可以商量的
( 2 ) oracle sequence 爽啊 这个可以重置序列的
( 3 )分布式的主键生成器 自己弄一个 java 的话好像有 atomic integer
BOYPT
2016-08-15 22:14:32 +08:00
记录当天的 start_id ,然后用自增 key 减去这个 id 不就有 order_id 了,有这么复杂么
chaegumi
2016-08-15 22:18:13 +08:00
mysql insert delayed into
3dwelcome
2016-08-15 23:52:12 +08:00
自增+LAST_INSERT_ID()
SoloCompany
2016-08-16 00:03:24 +08:00
1. 数据库有锁
2. 谁说 unique key 不能解决重复问题的,起码你加一个 order_date, order_number 的 unique key 就能解决重复问题(假如你并发没控制好的话就直接数据库出错)
3. mysql 支持复合 key 的 auto_increment, 但仅限于 MyISAM ,如果你的数据库场景可以使用 MyISAM 的话,这是一个最简单的解决方案
Mirana
2016-08-16 01:23:17 +08:00
弄个分布式锁,或者弄个发号器
songw123
2016-08-16 10:00:53 +08:00
做个序号生成器吧,完全自增也不太靠谱, order_number 如果是订单 ID 的话,是有业务意义的,直接自增会带来安全隐患
beneo
2016-08-16 13:30:43 +08:00
redis 来个自增数 num ,然后 2 << num 不就好了
beneo
2016-08-16 13:31:13 +08:00
我以为是 1 , 2 , 4 , 8 看错了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/299465

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX