SQL查閱筆記——多表查詢
阿新 • • 發佈:2022-04-17
DROP TABLE IF EXISTS emp; DROP TABLE IF EXISTS dept; # 建立部門表 CREATE TABLE dept( did INT PRIMARY KEY AUTO_INCREMENT, dname VARCHAR(20) ); # 建立員工表 CREATE TABLE emp ( id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(10), gender CHAR(1), -- 性別 salary DOUBLE, -- 工資 join_date DATE, -- 入職日期 dep_id INT, FOREIGN KEY (dep_id) REFERENCES dept(did) -- 外來鍵,關聯部門表(部門表的主鍵) ); -- 新增部門資料 INSERT INTO dept (dNAME) VALUES ('研發部'),('市場部'),('財務部'),('銷售部'); -- 新增員工資料 INSERT INTO emp(NAME,gender,salary,join_date,dep_id) VALUES ('孫悟空','男',7200,'2013-02-24',1), ('豬八戒','男',3600,'2010-12-02',2), ('唐僧','男',9000,'2008-08-08',2), ('白骨精','女',5000,'2015-10-07',3), ('蜘蛛精','女',4500,'2011-03-14',1), ('小白龍','男',2500,'2011-02-14',null); select * from emp; -- 多表查詢 select * from emp , dept; -- 笛卡爾積 : 有 A ,B兩個集合 取 A,B所有的組合情況 -- 消除無效資料 -- 查詢emp 和 dept 的資料 ,emp.dep_id = dept.did select * from emp , dept where emp.dep_id = dept.did;
連線查詢
內連線查詢 :相當於查詢AB交集資料
外連線查詢
左外連線查詢 :相當於查詢A表所有資料和交集部門資料
右外連線查詢 : 相當於查詢B表所有資料和交集部分資料