Как объединить две таблицы, которые объединены с двумя другими таблицами каждая - PullRequest
0 голосов
/ 28 апреля 2019

Я уже давно берусь за голову.Я хочу сделать запрос, который объединяет две таблицы, каждая из которых объединена с двумя другими таблицами, как показано на схеме ниже.Я знаю, как объединять таблицы, но на этом этапе я блокирую.

SELECT

 recipe_requirement.ID recipe_requirement_ID,
 recipe_requirement.RecipeID recipe_requirement_RecipeID,
 recipe_requirement.MaterialObjectTypeID,
 recipe_requirement_MaterialObjectTypeID,
 recipe_requirement.Quantity recipe_requirement_Quantity,    
 recipe_requirement.IsRegionItemRequired,
 recipe_requirement_IsRegionItemRequired,
 recipe.ID recipe_ID,
 recipe.Name recipe_Name,
 recipe.StartingToolsID recipe_StartingToolsID,
 items.ID items_ID,
 items.ContainerID items_ContainerID,
 items.ObjectTypeID items_ObjectTypeID,
 items.Quantity items_Quantity,
 items.FeatureID items_FeatureID,
 objects_types.ID objects_types_ID,
 objects_types.Name objects_types_Name,
 movable_objects.ID movable_objects_ID,
 movable_objects.ObjectTypeID movable_objects_ObjectTypeID,
 movable_objects.RootContainerID movable_objects_RootContainerID,
 movable_objects.IsComplete movable_objects_IsComplete,
 movable_objects.CustomNameId movable_objects_CustomNameId

FROM recipe_requirement

JOIN movable_objects ON movable_objects.RootContainerID = items.ContainerID

JOIN objects_types ON objects_types.ID = items.ObjectTypeID

JOIN recipe ON recipe.ID = recipe_requirement.RecipeID

JOIN items ON items.ObjectTypeID = recipe_requirement.MaterialObjectTypeID

JOIN objects_types ON objects_types.ID = Recipe_requirement.MaterialObjectTypeID

WHERE movable_objects.IsComplete = 1

Пример таблицы

T1 : recipe_requirement 
ID  1708
RecipeID    498
MaterialObjectTypeID    383
Quantity    1
IsRegionItemRequired    0

T2 - recipe 
ID  498
Name    Beef Stew
StartingToolsID 1054

T3 - items  
ID  5780
ContainerID 844
ObjectTypeID    383
Quantity    357
FeatureID   0

T1 связан на T2 со значением "498".T1 связан на T3 со значением 383 ".

И в то же время:

T3 - items  
ID  5780
ContainerID 844
ObjectTypeID    383
Quantity    357
FeatureID   0

T4 - objects_types  
ID  383
Name    Beef

T5 - movable_objects    
ID  728
ObjectTypeID    104
RootContainerID 844
IsComplete  1
CustomNameId    4

T3 связан на T4 со значением" 383 ".
T3 связан на T5со значением 844 ".

1 Ответ

0 голосов
/ 29 апреля 2019

Решение, которое я нашел:

`SELECT
    recipe_requirement.ID recipe_requirement_ID,
    recipe_requirement.RecipeID recipe_requirement_RecipeID,
    recipe_requirement.MaterialObjectTypeID recipe_requirement_MaterialObjectTypeID,
    recipe_requirement.Quantity recipe_requirement_Quantity,
    recipe_requirement.IsRegionItemRequired recipe_requirement_IsRegionItemRequired,
    recipe.ID recipe_ID,
    recipe.Name recipe_Name,
    recipe.StartingToolsID recipe_StartingToolsID,
    items.ID items_ID,
    items.ContainerID items_ContainerID,
    items.ObjectTypeID items_ObjectTypeID,
    items.Quantity items_Quantity,
    items.FeatureID items_FeatureID,
    objects_types.ID objects_types_ID,
    objects_types.Name objects_types_Name,
    movable_objects.ID movable_objects_ID,
    movable_objects.ObjectTypeID movable_objects_ObjectTypeID,
    movable_objects.RootContainerID movable_objects_RootContainerID,
    movable_objects.IsComplete movable_objects_IsComplete,
    movable_objects.CustomNameId movable_objects_CustomNameId
FROM recipe_requirement
JOIN recipe ON recipe.ID = recipe_requirement.RecipeID
JOIN (items
JOIN objects_types ON objects_types.ID = items.ObjectTypeID
JOIN movable_objects ON movable_objects.RootContainerID = items.ContainerID
) ON items.ObjectTypeID = recipe_requirement.MaterialObjectTypeID`
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...