我正在使用灯塔实现一个查询。
我正在使用@paginate指令,但它是一个复杂的条件,我想将它写入一个.php文件中。
我已经看过了,也想不出怎么做了,所以我需要帮助。
下面的方法无法得到关系并导致null。
graphql - Laravel灯塔分页结果-堆栈溢出Laravel Lighthouse paginate field result
分页指令x灯塔https://lighthouse-php.com/3/api-reference/directives.html#paginate
发布于 2022-09-26 07:41:36
看这个模板。
Schema.graphql:
"Get a list of all cars."
Cars(filter: carsFilter): [Car!]! @paginate(builder: "App\\GraphQL\\Queries\\Cars")Cars.php:
public function __invoke($_, array $args, ?GraphQLContext $context, ResolveInfo $resolveInfo):Builder {
$carsQuery = Cars::query();
// Do whatever you want with your query.
/* @var QueryBuilder|EloquentBuilder|ScoutBuilder|Relation $carsQuery */
return $carsQuery;
}注意,在php类中,必须返回查询生成器实例,而不是集合。
发布于 2022-09-30 21:54:11
当您在分页指令中使用构建器参数时,您将失去模型所具有的变异器。(因为要用自定义构建器替换查询生成器)。
如果可能的话,尝试使用作用域。这样,你就不会失去你的模型上的变异器或铸件。
Cars(filter: carsFilter): [Car!]! @paginate(scopes: ["myCondition", "mySecondCondition")可以将作用域作为模型中的函数添加,如下所示:
public function scopeMyCondition(Builder $query): Builder
{
return $query->where('color', '<>', 'red');
}
public function scopeMySecondCondition(Builder $query): Builder
{
return $query->whereIn('mts', '>', 100);
}https://stackoverflow.com/questions/73839582
复制相似问题