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

2025-05-29 0 102

问题描述

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

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

问题解决办法

在之前面对这样的问题的时候,我们知道,mysql提供了on duplicate key update或者replace into来解决。

使用on duplicate key update

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

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

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

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

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

使用replace into

代码如下:

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

?

1

2

3

4

5

6

7

8

9
replace into `work_log` (

`uid`,

`year`,

`mounth`,

`day`,

`status`

)

values

(1, 2016, 6, 2, 1)

效果如下图

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

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

?

1

2

3

4

5

6

7

8

9
replace into `work_log` (

`uid`,

`year`,

`mounth`,

`day`,

`status`

)

values

(1, 2016, 6, 2, 5)

效果如下图

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

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

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

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

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 完美解决Thinkphp3.2中插入相同数据的问题 https://www.kuaiidc.com/93754.html

相关文章

发表评论
暂无评论