2017-09-27 215 views
-1

,我有以下关系数据库:SQL查询联接条件

Bar(Name, Address, Licence) 
Beer(Name,Manufacture) 
Drinker(Name,Address) 
Frequents(DrinkerName,BarName) 
Likes(DrinkerName,BeerName) 
Sells(BarName,BeerName,Amount) 
Serves(BarName,BeerName) 

样品DDL语句:

CREATE TABLE `Bar` (
     `Name` varchar(255) NOT NULL, 
     `Address` varchar(255) DEFAULT NULL, 
     `Licence` varchar(255) DEFAULT NULL 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Bar` (`Name`, `Address`, `Licence`) VALUES 
    ('Deluxe', 'Luxvagen 2', 'Yes'), 
    ('Grace', 'Gracevagen 2', 'Yes'), 
    ('KrogBar', 'Barvagen 2', 'Yes'); 

    CREATE TABLE `Beer` (
     `Name` varchar(255) NOT NULL, 
     `Manufacture` varchar(255) DEFAULT NULL 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Beer` (`Name`, `Manufacture`) VALUES 
    ('Carlsberg', 'Coppers'), 
    ('Heiniken', 'Spendrups'), 
    ('Miller', 'DaMill'); 

    CREATE TABLE `Boor` (
     `Name` varchar(255) NOT NULL, 
     `Age` int(11) DEFAULT NULL 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    CREATE TABLE `Drinker` (
     `Name` varchar(255) NOT NULL, 
     `Address` varchar(255) DEFAULT NULL 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Drinker` (`Name`, `Address`) VALUES 
    ('Alex', 'Överbar 2'), 
    ('Bam', 'Påbar 2'), 
    ('Emil', 'Mittibar 2'), 
    ('Max', 'Ibar 2'), 
    ('Petra', 'Förebar 2'), 
    ('Rebecca', 'Efterbar 2'), 
    ('Sam', 'Underbar 2'); 

    CREATE TABLE `Frequents` (
     `DrinkerName` varchar(255) NOT NULL DEFAULT '', 
     `BarName` varchar(255) NOT NULL DEFAULT '' 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Frequents` (`DrinkerName`, `BarName`) VALUES 
    ('Emil', 'Deluxe'), 
    ('Max', 'Deluxe'), 
    ('Rebecca', 'Deluxe'), 
    ('Alex', 'Grace'), 
    ('Petra', 'Grace'), 
    ('Bam', 'KrogBar'), 
    ('Sam', 'KrogBar'); 

    CREATE TABLE `Likes` (
     `DrinkerName` varchar(255) NOT NULL DEFAULT '', 
     `BeerName` varchar(255) NOT NULL DEFAULT '' 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Likes` (`DrinkerName`, `BeerName`) VALUES 
    ('Bam', 'Carlsberg'), 
    ('Emil', 'Carlsberg'), 
    ('Rebecca', 'Carlsberg'), 
    ('Emil', 'Heiniken'), 
    ('Max', 'Heiniken'), 
    ('Petra', 'Heiniken'), 
    ('Sam', 'Heiniken'), 
    ('Alex', 'Miller'); 

    CREATE TABLE `Sells` (
     `BarName` varchar(100) DEFAULT NULL, 
     `BeerName` varchar(100) DEFAULT NULL, 
     `Amount` int(11) DEFAULT NULL 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Sells` (`BarName`, `BeerName`, `Amount`) VALUES 
    ('KrogBar', 'Miller', 3), 
    ('KrogBar', 'Carlsberg', 2), 
    ('KrogBar', 'Heiniken', 1), 
    ('Deluxe', 'Heiniken', 1); 

    CREATE TABLE `Serves` (
     `BarName` varchar(255) NOT NULL DEFAULT '', 
     `BeerName` varchar(255) NOT NULL DEFAULT '' 
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

    INSERT INTO `Serves` (`BarName`, `BeerName`) VALUES 
    ('Grace', 'Carlsberg'), 
    ('KrogBar', 'Carlsberg'), 
    ('Deluxe', 'Heiniken'), 
    ('Grace', 'Heiniken'), 
    ('KrogBar', 'Heiniken'), 
    ('KrogBar', 'Miller'); 

我想找到只光顾服务于啤酒,他们喜欢酒吧饮酒(假设每个饮酒者至少有一个酒吧)。 我该如何构建这样的查询?我知道我必须使用联接和子查询,我对他们中的任何一个都不陌生,但是我的所有实现都没有取得正确的结果。

+0

其更好地包括样本数据在您的文章 –

+0

请你使用MySQL或Oracle共享样本数据和格式化文本(不是图像) – zarruq

+0

所需输出? – jarlh

回答

0

这是你在找什么;

Select DISTINCT bar.Name,bar.Address,frequents.DrinkerName, likes.BeerName 
From 
Bar 
Join frequents on bar.Name = frequents.BarName 
join sells on bar.name = sells.BarName 
join likes on frequents.DrinkerName = likes.DrinkerName 

enter image description here

+0

这不回答仅有的部分 –