Laravel whereJson包含查询在5.7中不起作用

时间:2019-03-12 11:29:04

标签: php mysql json laravel

我的项目遇到了问题。我想搜索我的json数据。但是无法做到这一点。这是我的查询

$variations = User::whereJsonContains('addon->ram', '>', 0)->count();
return $variations;

我的json数据存储在addon列中,并且数据为

{"ram":"87","base-driven":"89"}

在此查询中,我收到错误提示

  

SQLSTATE [42000]:语法错误或访问冲突:1064您有一个   您的SQL语法错误; (SQL:从中选择count(*)作为聚合   users,其中0 json_contains(addon->'$。“ ram”',“>”)

我用Google搜索,但无法解决

预先感谢

1 个答案:

答案 0 :(得分:0)

只需尝试

$variations = User::where('addon->ram', '>', 0)->count();
return $variations;

如果遇到错误,请及时告知。

在将其另存为字符串时,可能需要执行类似的操作

WHERE JSON_EXTRACT(addon, "$[ram]") > 0;在Laravel中