我的表中有 json 类型的列 data
。该查询不起作用:
Advert::where('data->price', '>', 2000)->get();
作为响应,我得到了价格低于 2000 的元素。QueryBuilder 在数据库上运行它:
SELECT * FROM "adverts" WHERE "data"->>'price' > '2000'
我不知道出了什么问题。看起来价格正在转换为字符串,但在数据库中保存为整数。
{"price": 500}
最佳答案
PostgreSQL 将值作为字符串进行比较,从第一个字符开始。这就是为什么 500 比 2000 “更高”。您需要使用原始表达式将价格转换为整数:
Advert::where(DB::raw('("data"->>\'price\')::int'), '>', 2000)->get();
关于laravel - Eloquent json 字段 - 获取高于/低于某个值的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59516190/