php - 如果第二个表不匹配连接条件,laravel 从第一个表中获取结果
问题描述
如果条件不满足的连接表,我需要从第一个表中获取结果。
我有两个餐桌食物和 food_translation,在 food_translation 餐桌食物名称中以不同的语言保存,食物表中的默认名称。
如果食物翻译表中的语言条件不匹配,则需要从食物表中获取食物默认名称
$food = DB::table('Program')
->leftJoin('Meals', 'Program.meal_id', '=', 'Meals.meals_id')
->leftJoin('Food', 'Meals.food_id', '=', 'Food.food_id')
->leftJoin('food_translation', 'food_translation.food_id', '=', 'Food.food_id')
->select('Food.food_id','Food.food_name','food_translation.food_ame','Food.default_name')
->where('food_translation.locale', '=', 'ar')->get();
解决方案
所以当用户的当前语言。是阿拉伯语,您想显示食物的阿拉伯名称,但如果它不存在,则显示默认名称。在这种情况下,您永远不能使用where
子句,因为无论连接如何,where
子句都会消除连接结果中的任何和所有行不匹
您需要做的是在连接条件本身中添加 locale ='ar' 部分,这将只为您提供那些具有 locale = 'ar'但不影响其他表连接结果的food_translation 行。然后使用COALESCE()(或IFNULL())运算符将food_translation.food_name作为第一个参数,将Food.food_name作为第二个参数传递,因此如果food_translation.food_name不为空,它将被使用,否则使用Food.food_name。
$food = DB::table('Program')
->leftJoin('Meals', 'Program.meal_id', '=', 'Meals.meals_id')
->leftJoin('Food', 'Meals.food_id', '=', 'Food.food_id')
->leftJoin('food_translation', function ($join) {
$join->on('food_translation.food_id', '=', 'Food.food_id');
$join->on('food_translation.locale', '=', 'ar');
})
->select('Food.food_id','Food.food_name', DB::raw('COALESCE(food_translation.food_name,Food.default_name) as foodname')
)->get();
总而言之,您的原始 sql 可能看起来像这样
SELECT COALESCE(food_translation.food_name, Food.default_name) as foodname,Food.food_id
from program
left join meals on meals.meals_id = program.meal_id
left join food on food.food_id = meals.meals_id
LEFT JOIN food_translation on ( food_translation.food_id = food.food_id and food_translation.locale = 'ar' )
推荐阅读
- javascript - 单击链接或按钮时关闭汉堡菜单
- php - 为什么 php 会从不运行的类函数中执行回显?
- angular - 错误:类型不可分配给 Observable 类型
- amazon-web-services - 限制对用于托管静态网站的 S3 存储桶的直接访问的任何原因
- python - 如何转换大数据框
- sql - spark sql忽略按子句列分区中的空值
- java - 如何在列表中显示用户媒体列表
- r - tilegramR地图中的差距
- python-3.x - 使用多个几何重命名 GeoDataFrame 中的几何列
- flutter - 如何在 Android Studio 中每次运行时运行“颤振测试”?