php 重复写入数据,完美解决Thinkphp3.2中插入相同数据的问题

在Thinkphp3.2框架中,为避免插入重复数据,可以利用MySQL的ONDUPLICATEKEYUPDATE或REPLACEINTO语句。ONDUPLICATEKEYUPDATE在数据冲突时更新记录,而REPLACEINTO会删除旧记录并插入新记录。通过设置Model类的add()方法的第三个参数,可以实现类似功能,确保数据的唯一性和一致性。
摘要由CSDN通过智能技术生成

问题描述

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

bcf6aa0474e4670b85a3ea339f4561da.png

问题解决办法

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

使用ON DUPLICATE KEY UPDATE

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

7efacde3668378e72cb54d905ddcb728.png

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();

9d3cd4f092bb5fa35c25713ea996fb1d.png

使用REPLACE INTO

代码如下:

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

REPLACE INTO `work_log` (

`uid`,

`year`,

`mounth`,

`day`,

`status`

)

VALUES

(1, 2016, 6, 2, 1)

效果如下图

27d371db4f89949783a93d68c8fea5dc.png

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

REPLACE INTO `work_log` (

`uid`,

`year`,

`mounth`,

`day`,

`status`

)

VALUES

(1, 2016, 6, 2, 5)

效果如下图

e360b764c9c082e5eb7094e762e1f7c7.png

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方法中,我们可以看到有如下代码:

aa0ad173eacfa906203ae23c4fe6c894.png

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

以上这篇完美解决Thinkphp3.2中插入相同数据的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值