Home  >  Article  >  Backend Development  >  mysql - thinkphp模型类有防止重复插入的方法吗?

mysql - thinkphp模型类有防止重复插入的方法吗?

WBOY
WBOYOriginal
2016-06-06 20:12:391374browse

我看到防止重复插入有三种方法,http://blog.csdn.net/jbboy/article/detai...

但是看到了thinkPHP的 insert方法,有第二个参数可以设置,$replace,但是这只是第二种防止重复插入的方法啊,不支持第一种吗?

回复内容:

我看到防止重复插入有三种方法,http://blog.csdn.net/jbboy/article/detai...

但是看到了thinkPHP的 insert方法,有第二个参数可以设置,$replace,但是这只是第二种防止重复插入的方法啊,不支持第一种吗?

如果插入的数据来源于表单提交,TP文档里有个叫表单令牌的东西 表单令牌
也可以用TP自动验证中的unique验证某个字段是否唯一文档

第一种是数据库端的操作,当主键或者唯一索引的数值存在时,数据库会返回一个错误信息。不会插入数据。在TP里也可以在模型的自动验证里设置某一自动为'unique'验证方式。TP就会做一次是否存在的检索。

个人觉得,既然不能重复,为保证数据正确,就得从数据库方面做唯一约束,而不是依赖tp模型或任何代码实现,万一插入时候忘记调用模型呢,数据就可能出问题

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn