2017-02-18 64 views
1

我有以下两个表:SQL:问题连接表

attributevalueassign 

itm_id attr_value_id attr_id 
----- ------------- ------- 
396  237    1 
396  20    2 
715  274    1 
715  16    2 

attributevalue 

attr_id attr_value_id  attr_value 
------- -------------  ---------- 
1   237    3055020 
1   274    2454518 
2   16    Dunlop 
2   20    Vogue 

我需要能够编写一个查询,当我提供ITEM_ID(例如:396),我得到以下结果:

itm_id attr_value_id attr_id attr_value 
------ ------------- ------- ---------- 
396  237    1   3055020 
396  20    2   Vogue 

当我尝试使用INNER JOIN,我得到更多的行比我想:

SELECT  dbo.select_attributevalue.attr_value, dbo.select_attributevalueassign.itm_id 
FROM   dbo.select_attributevalueassign INNER JOIN 
         dbo.select_attributevalue ON dbo.select_attributevalueassign.attr_id = dbo.select_attributevalue.attr_id 
WHERE  (dbo.select_attributevalueassign.itm_id = 396) 

itm_id attr_value_id attr_id attr_value 
------ ------------- ------- ---------- 
396  237    1  3055020 
396  237    1  2454518 
396  20    2  Dunlop 
396  20    2  Vogue 

所以,我的想法是,我可能抄没有使用JOIN,但我不知道替代方法。我在这个网站上寻找了一个解决方案,并且有很多关于如何使用联接删除重复记录的问题,但是我没有看到与我所要求的类似的问题。我对SQL查询的知识是基本的,所以我不知道该怎么做。任何帮助将非常感激!

回答

2

您可能需要通过两列attr_value_idattr_id进行内部连接。试试这个查询:

SELECT  dbo.select_attributevalue.attr_value, dbo.select_attributevalueassign.itm_id 
FROM   dbo.select_attributevalueassign 
    INNER JOIN dbo.select_attributevalue ON 
    dbo.select_attributevalueassign.attr_id = dbo.select_attributevalue.attr_id 
    AND dbo.select_attributevalueassign.attr_value_id = dbo.select_attributevalue.attr_value_id 
WHERE  (dbo.select_attributevalueassign.itm_id = 396) 
+0

它很好用!谢谢! –