从多个表创建UNIQUE视图,其中忽略某些字段

时间:2015-08-05 08:50:27

标签: mysql view

我想创建一个类似的视图:

CREATE OR REPLACE VIEW all_cities AS
 SELECT city,date_added FROM tableA
 UNION DISTINCT
 SELECT city,date_added FROM tableB
 UNION DISTINCT
 SELECT city,date_added FROM tableC;

all_cities表应该只包含来自其他表的唯一城市条目,但是其他表可以添加相同的城市,这些城市具有不同的日期,这会破坏我的联合并导致在我的all_cities中包含所有这些重复项。 我仍然希望从至少一个合并结果中看到date_added字段(无关紧要)。

换句话说:如何创建一个视图,从3个表创建一个唯一的列表,但在执行唯一时忽略date_added字段。

由于

1 个答案:

答案 0 :(得分:0)

选择

的最佳方式
select city, min(date_added)
from ( 
  SELECT city,date_added FROM tableA
  UNION DISTINCT
  SELECT city,date_added FROM tableB
  UNION DISTINCT
  SELECT city,date_added FROM tableC
)A
GROUP BY city

但是MySQL不允许在view语句中使用子查询,但是你可以在view语句中使用view,所以我会用2个视图来寻找这个解决方案。

CREATE OR REPLACE VIEW all_cities_support_view AS
SELECT city,date_added FROM tableA
UNION DISTINCT
SELECT city,date_added FROM tableB
UNION DISTINCT
SELECT city,date_added FROM tableC;

CREATE OR REPLACE VIEW all_cities AS
SELECT city, min(date_added) as date_added
FROM all_cities_support_view 
GROUP BY city;