完美解决Thinkphp3.2中插入相同数据的问题
问题描述
今天在使用TP3.2插入数据的时候,为了避免插入相同的数据(所谓相同的数据,其主键相同或者是唯一索引的字段相同),我创建的索引如下图,主键索引为自增字段,不可能出现重复,即唯一索引可能会出现重复,我希望的是uid,year,mounth,day 这三个字段出现相同的话,就更新当前记录。
问题解决办法
在之前面对这样的问题的时候,我们知道,MySQL提供了ON DUPLICATE KEY UPDATE或者REPLACE INTO来解决。
使用ON DUPLICATE KEY UPDATE
插入数据之前,表中就一条记录,如下图
SQL语句如下,当插入记录时候,与表中已有记录相同,则更新改条记录,否则插入记录。
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
代码如下:
先执行如下代码插入一条数据
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status` ) VALUES (1, 2016, 6, 2, 1)
效果如下图
再次执行如下代码,就会更新上面插入的代码
REPLACE INTO `work_log` ( `uid`, `year`, `mounth`, `day`, `status` ) VALUES (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中插入相同数据的问题的详细内容,更多请关注其它相关文章!
上一篇: php使用html5实现多文件上传的方法
下一篇: 如何用php获取客户端正确的ip地址
推荐阅读
-
完美解决SQL server2005中插入汉字变成问号的问题
-
解决Vue中引入swiper,在数据渲染的时候,发生不滑动的问题
-
vue大数据表格卡顿问题的完美解决方案
-
Mysql5.7中使用group concat函数数据被截断的问题完美解决方法
-
完美解决python中ndarray 默认用科学计数法显示的问题
-
PHP中usort在值相同时改变原始位置问题的解决方法
-
用Excel 表格制作彩票走势图完美解决数据的连线问题
-
ASP 包含文件中的路径问题和使用单一数据库连接文件的解决方案
-
解决ASP.NET MVC返回的JsonResult 中 日期类型数据格式问题,和返回的属性名称转为“驼峰命名法”和循环引用问题
-
Python中LOADDATAINFILE语句导入数据到MySQL遇到问题的解决方案分享