根据相关表中的数据从表中获取数据列表,而不重复

问题描述

数据库中的表

  1. 我在MySQL STORESNEW_ARRIVALS中有两个表。
  2. 一个拥有所有商店的详细信息,而另一个表存储有新到达的详细信息。
  3. 两者均通过列store_id链接。

我要做什么:

  1. 列出所有有到达条目的商店,而不显示重复的商店。

我尝试过两个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
)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...