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查询的知识是基本的,所以我不知道该怎么做。任何帮助将非常感激!
它很好用!谢谢! –