当前位置:Gxlcms > PHP教程 > mysql-thinkphp模型类有防止重复插入的方法吗?

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

时间:2021-07-01 10:21:17 帮助过:3人阅读

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

人气教程排行