mysql 插入数据时,是先检测再插入,还是插入时提示重复键判断已经存在?这两种方式哪种好点?另外如果重复插入自增 id 会增加,这个会占用空间吗?

2018-08-10 16:28:29 +08:00
 faya
3335 次点击
所在节点    MySQL
3 条回复
wshcdr
2018-08-10 16:53:42 +08:00
这个问题有点奇怪
xud6
2018-08-10 16:56:55 +08:00
先检测再插入,并行处理会有点难。
ppyybb
2018-08-11 01:03:16 +08:00
看业务,如果比较简单就 on duplicate,自增的 ID 如果怕溢出就选择用 bigint 做主键,(如果并发不高的话可以将预分配的下一个自增 id 重新设置回来的)

如果业务复杂就没办法了,只能选择先检查后处理,这种情况可能遇到并发问题导致检查后其他线程又插入了,最好业务上做处理,利用 unique key 抛出的异常判断。

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

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

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

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

© 2021 V2EX