当前位置:Gxlcms > PHP教程 > 在Thinkphp3.2中插入相同数据的解决方法

在Thinkphp3.2中插入相同数据的解决方法

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

下面小编就为大家带来一篇完美解决Thinkphp3.2中插入相同数据的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

问题描述

今天在使用TP3.2插入数据的时候,为了避免插入相同的数据(所谓相同的数据,其主键相同或者是唯一索引的字段相同),我创建的索引如下图,主键索引为自增字段,不可能出现重复,即唯一索引可能会出现重复,我希望的是uid,year,mounth,day 这三个字段出现相同的话,就更新当前记录。

问题解决办法

在之前面对这样的问题的时候,我们知道,MySQL提供了ON DUPLICATE KEY UPDATE或者REPLACE INTO来解决。

使用ON DUPLICATE KEY UPDATE

插入数据之前,表中就一条记录,如下图

SQL语句如下,当插入记录时候,与表中已有记录相同,则更新改条记录,否则插入记录。

  1. INSERT INTO `work_log` (
  2. `uid`,
  3. `year`,
  4. `mounth`,
  5. `day`,
  6. `status`
  7. )
  8. VALUES
  9. (1, 2016, 6, 3, 1)
  10. ON DUPLICATE KEY
  11. UPDATE
  12. `status` =
  13. VALUES
  14. (`status`),
  15. `updated_ts` = NOW();

使用REPLACE INTO

代码如下:

先执行如下代码插入一条数据

  1. REPLACE INTO `work_log` (
  2. `uid`,
  3. `year`,
  4. `mounth`,
  5. `day`,
  6. `status`
  7. )
  8. VALUES
  9. (1, 2016, 6, 2, 1)

效果如下图

再次执行如下代码,就会更新上面插入的代码

  1. REPLACE INTO `work_log` (
  2. `uid`,
  3. `year`,
  4. `mounth`,
  5. `day`,
  6. `status`
  7. )
  8. VALUES
  9. (1, 2016, 6, 2, 5)

效果如下图

ON DUPLICATE KEY UPDATE与REPLACE INTO区别

当出现相同的值时候,ON DUPLICATE KEY UPDATE是更新已经存在的记录,REPLACE INTO是删除之前的记录,然后插入新的记录。

Thinkphp3.2中解决办法

在Thinkphp3.2中,通过add()函数的第三个参数来处理插入相同数据的问题。

Model.class.PHP中add()方法,调用了Db.class.php中insert中方法,在insert方法中,我们可以看到有如下代码:

其中$replace 正好是add方法中第三个参数。

以上就是在Thinkphp3.2中插入相同数据的解决方法的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行