Rumah  >  Artikel  >  pembangunan bahagian belakang  >  mysql - thinkphp模型类有防止重复插入的方法吗?

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

WBOY
WBOYasal
2016-06-06 20:12:391373semak imbas

我看到防止重复插入有三种方法,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模型或任何代码实现,万一插入时候忘记调用模型呢,数据就可能出问题

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn