首页 > 解决方案 > 雄辩的 json 字段 - 获取高于/低于某个值的记录

问题描述

data的表中有 json 类型的列。该查询不起作用:

Advert::where('data->price', '>', 2000)->get();

作为回应,我得到了价格低于 2000 的元素。QueryBuilder 在 db 上运行:

SELECT * FROM "adverts" WHERE "data"->>'price' > '2000'

我不知道出了什么问题。看起来价格正在转换为字符串,但在数据库中保存为整数。

{"price": 500}

标签: laravelpostgresqleloquent

解决方案


PostgreSQL 将值作为字符串进行比较,从第一个字符开始。这就是 500 比 2000“高”的原因。您需要使用原始表达式将价格转换为整数:

Advert::where(DB::raw('("data"->>\'price\')::int'), '>', 2000)->get();

推荐阅读