Tag
id, type, transloations, creaed_at, updated_at
TagTranslation
id, tag_id, name, language
我使用graphql,我想按类型,名称和语言获取标签列表
{ tags(name:"tag1", language:"en, type:3){
id,
type,
translations{
id,
name,
language,
}
}
}
所以我创建如下的解析器
@Query(returns => [Tag])
tags(@Args() tagArgs: TagArgs): Promise<Tag[]> {
const where = {
...(tagArgs.type) && {type: tagArgs.type}
};
const include_where = {
...(tagArgs.name) && {name: { [Op.like]: `%${tagArgs.name}%` }},
...(tagArgs.language) && {language: tagArgs.language}
};
return this.tagService.findAll({
where: where,
include: {
as: 'translations',
model: TagTranslation,
where: include_where,
required: true,
}
});
}
@Query(returns => Tag)
tag(@Args({name: 'id', type: ()=> Int}) id: number): Promise<Tag>{
return this.tagService.get(id)
}
@ResolveProperty()
async translations(@Parent() tag): Promise<TagTranslation[]>{
const { id } = tag;
return await this.tagTranslationService.findAll({tag_id: id});
}
当我调用标签时,查询被调用两次
首先,执行查询以获取所需的结果。
第二,
SELECT `id`, `tag_id`, `name`, `language`, `created_at`, `updated_at` FROM `tag_translation` AS `TagTranslation` WHERE `TagTranslation`.`tag_id` = 1;
再次调用查询,所以我无法获得想要的结果。
我认为第二个查询由于ResolveProperty而被调用,因此我删除了ResolveProperty。之后,标签查询不包含标签翻译信息...
我该如何解决这个问题?还是还有其他想法?
答案 0 :(得分:0)
我该如何解决这个问题?还是还有其他想法?
实体之间的关系应在字段解析器(@ResolveProperty()
)级别上解析,因为当某人仅请求id
和type
时,您仍将在{{ 1}}进行SQL查询。