ThinkPHP(8)——add()时覆盖重复数据

来源:互联网 发布:淘宝网首页长款羽绒服 编辑:程序博客网 时间:2024/06/18 03:48

有时我们在插入数据时,需要覆盖重复数据。如果是sql语句,我们可以使用replace into代替insert into,它会自动判断主键或唯一约束的字段是否重复,重复则覆盖,不重复则插入

在thinkphp中,也支持replace into同样的效果

首先,我们必须给用来判断是否重复的字段添加一个唯一索引,如图:

这里写图片描述

查看tp的源码可以发现add和addAll定义如下:

public function addAll($dataList,$options=array(),$replace=false)

在调用时,只需将最后一个参数设为true即可,如:

 D("table")->addAll($add_data,array(),true);
0 0
原创粉丝点击