我要在航班表中列出所有航班,其中出发和到达时间如表2所示。
特殊性是,飞行中的出发地为XXXX -dsdjqlkdjlqs或XXXXdkjfhkds等,而表2中仅为XXXX
代码:
CREATE TABLE flights
(`Name` varchar(10), `Departure` varchar(50), `Arrival` varchar(10), `Pass` int, `Cargo` int, `Dist` int)
;
INSERT INTO flights
(`Name`, `Departure`, `Arrival`, `Pass`, `Cargo`, `Dist`)
VALUES
('444 737vvv', 'LFLL gee', 'LPMAdsf', 200, 2000, 12),
('gg737vvv', 'LPMA-egege', 'LFLLdsf', 3000, 0, 13),
('747vvv', 'LFLLèèegege', 'LPMAdsf', 0, 5000, 15),
('747vvv', 'OTHHèèegege', 'LPMAdsf', 0, 5000, 15),
('747vvv', 'OMDBèèegege', 'LPMAdsf', 0, 5000, 15),
('a320vvv', 'EGKK-egege', 'LFPOdd', 0, 6000, 14)
;
CREATE TABLE Table2
(`Dep` varchar(21), `Arri` varchar(21),`Type` varchar(21))
;
INSERT INTO Table2
(`Dep`, `Arri`, `type`)
VALUES
('LFLL', 'LFPG', 'cargo'),
('LFPG', 'LFLL', 'cargo'),
('LFLL', 'LPMA', 'com'),
('LPMA', 'LFLL', 'cargo'),
('LFPO', 'EGKK', 'cargo'),
('EGKK', 'LFPO', 'com')
;
我测试了:
select flights.name,
flights.Departure
from flights
where substr(flights.Departure, 1, 4) in (select Dep from table2) and
substr(flights.Arrival, 1, 4) in (select Arri from table2)
;
范例:
我从LFLL飞往LFPG
在表2中,您有航空公司:
LFLL LFPG
LFMT LFPO等...。
根据您的要求,如果我从LFLL飞往LFPO航班出现并且不会出现,因为LFLL到LFPO不是航空公司。
http://sqlfiddle.com/#!9/026d6
最佳答案
我认为以下是您要寻找的:
Select
flights.name,
flights.Departure
from
flights
inner join Table2
on Table2.Dep = SUBSTRING(flights.Departure,1,4) and Table2.Arri = SUBSTRING(flights.Arrival,1,4)
;
您只需要SUBSTRING而不是通配符,因为您只需要FLIGHTS表条目的一部分。另外,您需要包括到达约束。
关于mysql - 来自表航类的SQL JOIN返回记录对应于表2,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35870466/