完美解决Thinkphp3.2中插入相同数据的问题

问题描述

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

问题解决办法

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

使用ON DUPLICATE KEY UPDATE

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

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

rush:xhtml;"> INSERT INTO `work_log` ( `uid`,`year`,`mounth`,`day`,`status` ) VALUES (1,2016,6,3,1) ON DUPLICATE KEY UPDATE `status` = VALUES (`status`),`updated_ts` = Now();

使用REPLACE INTO

代码如下:

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

rush:xhtml;"> REPLACE INTO `work_log` ( `uid`,2,1)

效果如下图

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

rush:xhtml;"> REPLACE INTO `work_log` ( `uid`,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中插入相同数据的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

(1)创建数据表: CREATE TABLE IF NOT EXISTS `think_form` ...
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的...
(1)创建模版:/App/Home/View/Form/edit.html   <FORM m...
自定义配置文件user.php: <?php return array(    \'se...
在一些成熟的CMS系统中,后台一般都包含一个配置中心(如织梦...
废话不多说先上图预览下,即本博客的分页; 这个分页类是在...