1. 程式人生 > 其它 >SQL查閱筆記——多表查詢

SQL查閱筆記——多表查詢

 


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表所有資料和交集部分資料