> 백엔드 개발 > PHP 튜토리얼 > mysql - PHP最佳实践:添加唯一数据的时提前查询数据进行比较,还是用try catch处理呢?哪种效率高?

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

WBOY
풀어 주다: 2016-06-06 20:06:57
원래의
1009명이 탐색했습니다.

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

  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可以用REPLACE INTO

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

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

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿