mysql 怎么查询json 数组?

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

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

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案
select * from test where extra->'$[0]' = 24

Laravel

Laravel

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

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

1年前 评论

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

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

Laravel

Laravel

1年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!