mysql - 根据相关表中的数据从表中获取数据列表,不重复
问题描述
数据库中的表:
- 我在 MySQL
STORES
和NEW_ARRIVALS
. - 一个有所有商店的详细信息,另一个表存储新到货的详细信息(如果有的话)。
- 两者都通过 column 链接
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.is_active,
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;
希望这是你想要的。
推荐阅读
- java - RTC + Jenkins - 仅为更改的组件构建
- output - 如何在 Informatica 中获取学生的通过/失败状态
- php - 如何使用请求字段来保存具有该值的新变量?
- ios - PKToolPicker(PencilKit)的初始位置?
- concurrency - Rust async-await:检查列表中的任何未来是否同时解析为真?
- spring-boot - Couchbase 的 Spring Data - 元数据信息
- python - 从 OpenCV 写入 GStreamer 管道不起作用
- reactjs - 搜索后如何清除输入字段(删除搜索词)?
- javascript - CakePHP 3:发送jQuery-Tabledit的Ajax Post请求时出现禁止错误
- python - 从文本文件中计算特定单词的列表-Python