search

Home  >  Q&A  >  body text

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

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

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

PHP中文网PHP中文网2823 days ago371

reply all(3)I'll reply

  • 巴扎黑

    巴扎黑2017-04-10 17:13:21

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

    reply
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-10 17:13:21

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

    reply
    0
  • 巴扎黑

    巴扎黑2017-04-10 17:13:21

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

    reply
    0
  • Cancelreply