php foreach有一条数据重复,php使用foreach循环时最后一组数据重复,原因是使用了“&”符号...

新手很容易犯这样一个错误,直接拿网上的例子来说明问题。

代码://数组

$arr = ["foo", "bar", "baz"];

//循环

foreach ($arr as &$item) {

/* do nothing by reference */

}

//打印

print_r($arr);

//循环

foreach ($arr as $item) {

/* do nothing by value */

}

//打印

print_r($arr); // $arr has changed....why?

输出:Array

(

[0] => foo

[1] => bar

[2] => baz

)

Array

(

[0] => foo

[1] => bar

[2] => bar

)

这是发现两次输出结果不一样,第二次输出不是我们预期的结果,数组里最后一个元素被替换,和上一个元素重复。其实原因就是第一次循环时使用了“&”符号,这个问题解释清楚比较绕,不作过多解释,直接说解决办法,在第二次循环之前加如下代码:unset($item); // This will fix the issue.

参考链接:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 PHP 的 `foreach` 循环读取 JSON 数据,并将其插入到数据,可以采用以下一些方法来防止插入数据重复: 1. 设置数据库字段的唯一性约束,例如将某个字段设置为主键或唯一索引,当插入如果该字段的值已经存在,则会触发唯一性约束的异常,从而防止插入重复数据。 2. 在插入数据前,先进行查询,检查该数据是否已经存在于数据库中,如果存在,则不进行插入操作。 例如,可以先查询某个字段的值是否已经存在,例如: ```php // 假设 $data 是从 JSON 数据中读取出来的一条记录 $value = $data['field_name']; $sql = "SELECT COUNT(*) FROM table_name WHERE field_name = :value"; $stmt = $pdo->prepare($sql); $stmt->bindParam(':value', $value); $stmt->execute(); $count = $stmt->fetchColumn(); if ($count == 0) { // 该记录不存在,进行插入操作 // ... } ``` 3. 可以使用 `INSERT IGNORE` 或 `INSERT ... ON DUPLICATE KEY UPDATE` 等语法进行插入操作,这些语法在插入数据,如果遇到重复的键值,则会忽略插入或者更新已有数据。 例如,使用 `INSERT IGNORE` 语法进行插入操作: ```php // 假设 $data 是从 JSON 数据中读取出来的一条记录 $sql = "INSERT IGNORE INTO table_name (field1, field2, field3) VALUES (:val1, :val2, :val3)"; $stmt = $pdo->prepare($sql); $stmt->bindParam(':val1', $data['field1']); $stmt->bindParam(':val2', $data['field2']); $stmt->bindParam(':val3', $data['field3']); $stmt->execute(); ``` 以上是几种常见的防止插入重复数据的方法,具体使用哪种方法,可以根据实际情况进行选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值