gpt4 book ai didi

php - 如果第二个表不匹配连接条件,laravel 从第一个表中获取结果

转载 作者:可可西里 更新时间:2023-11-01 08:24:10 24 4
gpt4 key购买 nike

我有一个要求,如果条件不满足的连接表,我需要从第一个表中获取结果。

我有两个表 food 和 food_translation,在 food_translation 表中以不同语言保存的食物名称和食物表中的默认名称。

如果语言条件在food_translation表中不匹配,则需要从food表中获取食物default_name

$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 子句将消除连接结果中不匹配的所有行(即使使用左连接)。如果 food_translation 表中没有行具有 locale = 'ar' 因此在连接结果中也没有行locale = 'ar' 结果一切都被淘汰了。

您需要做的是在连接条件本身中添加 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' )

关于php - 如果第二个表不匹配连接条件,laravel 从第一个表中获取结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50227660/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com