进行数据查询时,获取数据的变量 Undefined index

因为数据量过大,索引使用的是字符串类型,我在使用条件查询时,提示报错

进行数据查询时,获取数据的变量Undefined index

进行数据查询时,获取数据的变量Undefined index

请问是什么原因导致

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

file

5年前 评论
laravel_mouse (楼主) 5年前
讨论数量: 4

第三行,$parm默认值应该要是数组[]。

5年前 评论
laravel_mouse (楼主) 5年前

file

5年前 评论
laravel_mouse (楼主) 5年前
jcc123

这样查舒服一点

$data=app(App\Services\Search\Db\MainService::class)->startFetchData();
//todo

MainService

<?php namespace App\Services\Search\Db;


use App\Services\Search\Db\Filter\MainFilter;
use DB;


class MainService
{

    protected $mainFilter;

    public function __construct(MainFilter $mainFilter)
    {
        $this->mainFilter = $mainFilter;
    }
    public function startFetchData()
    {
        return DB::table('xxx')->where(function ($query){
            $this->mainFilter->apply($query);
        })->get();

    }


}

QueryFilter

<?php namespace App\Services\Search\Db\Filter;


use Illuminate\Http\Request;
use Illuminate\Database\Query\Builder;

abstract class QueryFilter
{

    protected $request;
    protected $builder;

    public function __construct(Request $request)
    {
        $this->request = $request;
    }

    public function apply(Builder $builder)
    {
        $this->builder = $builder;
        foreach ($this->filters() as $name => $value) {

                if (method_exists($this, $name)) {
                    call_user_func_array([$this, $name],[$value]);
                }


        }

        return $this->builder;
    }
    public function filters()
    {
        return $this->request->all();
    }
}

MainFilter

<?php


namespace App\Services\Search\Db\Filter;


class MainFilter extends QueryFilter
{

    public function status($status)
    {
       return $this->builder->where('status',$status);
    }

}
5年前 评论

....这个代码再精简下吧

5年前 评论

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