问题描述
数据库中的表
- 我在MySQL
STORES
和NEW_ARRIVALS
中有两个表。 - 一个拥有所有商店的详细信息,而另一个表存储有新到达的详细信息。
- 两者均通过列
store_id
链接。
我要做什么:
- 列出所有有到达条目的商店,而不显示重复的商店。
我尝试过两个SQL查询:
SELECT
stores.id,stores.name
new_arrivals.id,new_arrivals.title,new_arrivals.store_id
FROM
stores,new_arrivals
上面的SQL有效,但列出了多个存储。对于商店中的每个新进货,都有一行。我只希望每个商店输入一个条目。
所以我尝试了以下SQL查询:
SELECT
na.id,na.is_active,na.store_id
FROM
new_arrivals as na
group by na.store_id
以上查询给出了唯一的store_ids
,但我可以从stores
表中获取信息。
我进一步尝试了以下操作,但没有结果:
SELECT
na.id,na.store_id
FROM
new_arrivals as
INNER JOIN (
SELECT name
FROM stores as sl
) As locations
group by na.store_id
实现此目标的最佳方法是什么?
解决方法
这仅提供那些有新到条目的商店。
SELECT
distinct s.id,s.name
FROM stores s
INNER JOIN new_arrivals na on na.store_id = s.store_id;
希望这就是您想要的。
,查询的问题是您缺少表之间的联接条件。没有它,您实际上是在生成表的笛卡尔积。
此:
FROM
stores,new_arrivals
应写为:
FROM stores
INNER JOIN new_arrivals
ON new_arrivals.store_id = stores.store_id
但是即使这样,您每次到达仍会得到一行,这似乎并不是您想要的。我认为您想要exists
:
select s.*
from store s
where exists (
select 1
from new_arrivals na
where na.store_id = s.store_id
)