首页  >  问答  >  正文

通过关联,在其他表中搜索Laravel的JSON列

我尝试编写搜索代码,这是我的代码:

$services = Service::query()->with('plans')->latest();


    if ($request->service_name) {
               $services = $services->whereRaw("CONVERT(JSON_EXTRACT(name, '$.ar') using 'utf8') LIKE  '%$request->service_name%' ")
                ->orWhereRaw("CONVERT(JSON_EXTRACT(name, '$.en') using 'utf8') LIKE  '%$request->service_name%' ")
                ->orWhereRaw("CONVERT(JSON_EXTRACT(name, '$.he') using 'utf8') LIKE  '%$request->service_name%' ");     
    }

        if ($request->plan_name) {
            $plan_name = $request->plan_name;
            $services = $services->whereHas('plans', function ($q) use ($plan_name) {
                $q->where('name->en','Like','%'.$plan_name.'%');
            });
       }

        return $services->get();

但是当我在请求中发送 plan_name 时,代码按服务名称而不是计划名称进行过滤

我尝试过何时在请求中发送计划名称代码按计划名称过滤数据,但它不起作用

P粉596161915P粉596161915209 天前356

全部回复(1)我来回复

  • P粉807471604

    P粉8074716042024-02-27 13:45:32

    雷雷

    回复
    0
  • 取消回复