mysql 怎么查询json 数组?

比如 extra 字段 怎么查询第一个等于 23

[23,'aaa','测试测试']

User::query()->where(‘extra->0’,23)->first();
这样写不对喃?

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
最佳答案
select * from test where extra->'$[0]' = 24

Laravel

Laravel

2年前 评论
讨论数量: 6
User::query()->whereRaw("JSON_CONTAINS(字段名, ?, '$')", [(string) 23])->first();
2年前 评论
sunlight_w (作者) 2年前

User::query()->whereJsonContains('attribute_product.values', $someValue)->get()

2年前 评论

你这种是数组类型的 json, 不是对象类型的 json, 用 -> 符号你也试过了不对,不知道这样可不可以,我没试过 😓:

User::query()->where('extra[0]',23)->first();
2年前 评论
select * from test where extra->'$[0]' = 24

Laravel

Laravel

2年前 评论