• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql – PHP最佳实践:添加唯一数据的时提前查询数据进行比较,还是用try catch处理呢?哪种效率高?

php 搞代码 4年前 (2022-01-25) 17次浏览 已收录 0个评论
文章目录[隐藏]

常见场景:假如我要添加一行唯一的相册和用户的收藏记录。
我目前想到两种方法:

  1. 提前查询是否已经存在aid和uid,然后判断是否进行添加————代码层面。

  2. 给aid和uid添加unique key,然后利用php的try catch进行处理————数据库层面。

以上两种方式哪种更好呢?有没有一些好的php最佳实践?

回复内容:

常见场景:假如我要添加一行唯一的相册和用户的收藏记录。
我目前想到两种方法:

  1. 提前查询是否已经存在aid和uid,然后判断是否进行添加————代码层面。

  2. 给aid和uid添加unique key,然后利用php的try catch进行处理————数据库层面。

以上两种方式哪种更好呢?有没有一些好的php最佳实践?

两种都可以,不管哪种方法UNIQUE(aid, uid)都是必须的。
从效率来说,直接try比较好,注意catch的时候要识别错误码,如果不是唯一键冲突引发的异常要另行处理。

给关键字段加 Unique索引 啊!直接看数据库的返回值就好了,你程序再怎么判断,也不可能快过数据库本身啊。

MySQL? REPLACE INTO ……

1 简单直接

1、MySQL可以用REP

4本文¥来源gao!%daima.com搞$代*!码$网9

搞代gaodaima码

LACE INTO

2、否则的话,先查询是否存在,存在则替换,不存在则插入。

注意防止重复提交,生成2条相同纪录(前端表单使用token令牌,在上面2中使用事务)。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql – PHP最佳实践:添加唯一数据的时提前查询数据进行比较,还是用try catch处理呢?哪种效率高?

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址