gpt4 book ai didi

php - 插入查询直接在 MySQL 中工作,而不是通过 Code Igniter 它传递一个空值

转载 作者:行者123 更新时间:2023-11-29 07:18:29 25 4
gpt4 key购买 nike

在我的 Code Igniter (PHP) 应用程序中,我使用以下查询插入多行:

INSERT INTO attribute_data (attribute_ID,product_ID,attribute_value) VALUES (2,3,123),(2,3,543)

两行名为“attribute_value”的列都设置为 0。

但是,当我将查询直接粘贴到 phpMyAdmin 时,它会使用给定的数字(在我的示例中为 123 和 543)设置“attribute_value”列。所以,我的猜测是查询没有问题。但请纠正我。

可能不是很有帮助,但这是我的 Code Igniter 代码:

$sql = "INSERT INTO attribute_data (attribute_ID,product_ID,attribute_value) VALUES (2,3,123),(2,3,534)";
$this->db->query($sql);

关于我一直在看的一些信息:

  • 我已经尝试过使用引号,尽管它是一个整数。
  • 'attribute_value' 列不是主键

更新

我已经启用了分析。分析输出中的查询是相同的。

更新 2

我尝试使用 insert_batch() 方法得到相同的结果。记录仍在添加 0 而不是给定值。

$this->db->insert_batch('attribute_data',$insert_data);

最佳答案

感谢您的帮助。确认我的代码和查询正常就足以让我开始考虑缓存。

我首先检查了 MySQL 的缓存,但这是开箱即用的。 Code Igniter 缓存导致了这里的问题。当然不是最终的解决方案,但下面的方法帮了我很多。

$this->db->cache_delete_all();

一旦我在插入数据之前删除缓存,就会插入正确的值。因此,列 attribute_value 以某种方式在缓存中。现在我的任务是让它在打开 Code Igniter 缓存的情况下继续工作。

再次感谢,你太棒了!

关于php - 插入查询直接在 MySQL 中工作,而不是通过 Code Igniter 它传递一个空值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57845762/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com