《PHP实战:完美解决Thinkphp3.2中插入相同数据的问题》要点:
本文介绍了PHP实战:完美解决Thinkphp3.2中插入相同数据的问题,希望对您有用。如果有疑问,可以联系我们。
相关主题:thinkphp教程
PHP应用问题描述
PHP应用今天在使用TP3.2插入数据的时候,为了避免插入相同的数据(所谓相同的数据,其主键相同或者是唯一索引的字段相同),我创建的索引如下图,主键索引为自增字段,不可能出现重复,即唯一索引可能会出现重复,我希望的是uid,year,mounth,day 这三个字段出现相同的话,就更新当前记录.
PHP应用
PHP应用问题解决办法
PHP应用在之前面对这样的问题的时候,我们知道,MySQL提供了ON DUPLICATE KEY UPDATE或者REPLACE INTO来解决.
PHP应用使用ON DUPLICATE KEY UPDATE
PHP应用插入数据之前,表中就一条记录,如下图
PHP应用
PHP应用SQL语句如下,当插入记录时候,与表中已有记录相同,则更新改条记录,否则插入记录.
PHP应用
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();
PHP应用
PHP应用使用REPLACE INTO
PHP应用代码如下:
PHP应用先执行如下代码插入一条数据
PHP应用
REPLACE INTO `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
)
VALUES
(1, 2016, 6, 2, 1)
PHP应用效果如下图
PHP应用
PHP应用再次执行如下代码,就会更新上面插入的代码
PHP应用
REPLACE INTO `work_log` (
`uid`,
`year`,
`mounth`,
`day`,
`status`
)
VALUES
(1, 2016, 6, 2, 5)
PHP应用效果如下图
PHP应用
PHP应用ON DUPLICATE KEY UPDATE与REPLACE INTO区别
PHP应用当出现相同的值时候,ON DUPLICATE KEY UPDATE是更新已经存在的记录,REPLACE INTO是删除之前的记录,然后插入新的记录.
PHP应用Thinkphp3.2中解决办法
PHP应用在Thinkphp3.2中,通过add()函数的第三个参数来处理插入相同数据的问题.
PHP应用Model.class.PHP中add()方法,调用了Db.class.php中insert中方法,在insert方法中,我们可以看到有如下代码:
PHP应用
PHP应用其中$replace 正好是add方法中第三个参数.
PHP应用以上这篇完美解决Thinkphp3.2中插入相同数据的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持维易PHP.
转载请注明本页网址:
http://www.vephp.com/jiaocheng/392.html