如何解决根据相关表中的数据从表中获取数据列表,而不重复
数据库中的表
- 我在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
)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。