当参数作为整数传递时,Laravel 返回零而不是实际的单元格值

Posted

技术标签:

【中文标题】当参数作为整数传递时,Laravel 返回零而不是实际的单元格值【英文标题】:Laravel returns zero instead of the actual cell value when a parameter passed as an integer 【发布时间】:2020-08-22 14:04:46 【问题描述】:

我有一个来自 MariaDB 视图的非常简单的查询:

SELECT c.amount, c.discount 
FROM factors_view as c
WHERE c.factor_id = 358

当我在 HeidiSQL 中运行此查询时,我得到以下结果:amount = 16000, discount = 1200

但在 Laravel 5.7 原始查询中

$result = \DB::select("
   SELECT c.amount,c.discount 
   FROM factors_view as c
   WHERE c.factor_id = 358"
);

结果:amount = 16000, discount = 0 当我把参数放在引号之间时:

$result = \DB::select("
   SELECT c.amount,c.discount 
   FROM factors_view as c
   WHERE c.factor_id = '358'"
);

结果:amount = 16000, discount = 1200

c.factor_id 的类型是int(10) unsigned

这对我来说很奇怪;因为区别在于查询条件,而不是选择!

输出是同一行,特定列上的值为零!

有人知道发生了什么吗?

这是我的两个查询的查询日志:

1)
query:"select `c`.`amount`, `c`.`discount` from `factors_view` as `c` where `c`.`factor_id` = ?"
bindings:[0:358]

2)
query:"select `c`.`amount`, `c`.`discount` from `factors_view` as `c` where `c`.`factor_id` = ?"
bindings:[0:"358"]

【问题讨论】:

你能分享以上每个产生的原始查询吗? (如***.com/questions/41140975/… 所述) 您正在从视图中选择factor_id,您可以从源表中选择它而不用单引号括起来吗?它会给你同样的结果吗? @apokryfos 您好我已经编辑了帖子并添加了查询日志。 我不知道为什么,但尽管您共享了一个原始的未参数化查询,但查询日志显示了一个参数化查询。这可能解释了这种差异,因为某处可能发生了意外的演员表 【参考方案1】:

最后,我找到了这个麻烦的错误的原因。为了更正错误,我在视图中更改了 factor_id 的类型:

CAST(factor_id AS UNSIGNED) AS factor_id 

而且它工作正常。

虽然错误已修复,但我仍然没有意识到这种行为。 where 条件必须影响行,而不是单元格的值。这可能是一个学说/dbal 错误?!

【讨论】:

【参考方案2】:

请提供SHOW CREATE TABLE

factor_idVARCHAR,而它应该是INT

int_col = 123     -- can use index
int_col = '123'   -- can use index
char_col = 123    -- 123 dominates; must check all rows, converting char_col to int
char_col = '123'  -- can use index

【讨论】:

以上是关于当参数作为整数传递时,Laravel 返回零而不是实际的单元格值的主要内容,如果未能解决你的问题,请参考以下文章

getElementsByTagName 返回零而不是 null 为啥

为啥PHP传递参数值为0时,empty判断参数为真

返回带有零而不是空值的 Access 记录集

如何将数组作为 Laravel 查询生成器的 SELECT 参数传递

如何使 OUTER JOIN 返回零而不是 NULL

当数组值为零而不是空时,c循环停止