[英]Laravel get Eloquent relation with default value if relation is not present?
我有一个Post
模型中,每个岗位都有例如许多翻译: ru
, fr
, en
- ( post_translations
表),用于获取所有文章与特定的翻译工作代码是这样的(如fr
):
$locale = 'fr';
$posts = Post::with([
'translations' => function($q) use($locale){
$q->where('language', $locale);
}
])->get();
但是$posts
中的一些没有fr
翻译,所有posts都有en
translation。
我想获取所有带有fr
翻译的帖子,而对于没有fr
帖子,请返回en
translation!
我是否必须手动执行此操作? ei遍历所有帖子并在没有fr
或laravel方式的帖子上添加en
翻译。
尝试此解决方案以获取所有fr:
$posts = Post::whereHas('translations', function($q) use($locale){
$q->where('language', $locale);
})->get();
希望对您有所帮助:)
从您写的内容来看,我知道帖子总是用英语撰写,然后再翻译成其他语言。
我不知道您有什么用,但是我建议您使用法语和英语翻译查询所有帖子,然后在打印时过滤它们
$locale = 'fr';
$posts = Post::with([
'translations' => function($q) use($locale){
$q->where('language', $locale);
$q->orWhere('language', 'en');
}
])->get();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.