MySql 中 有其中连接方式:
Sample:
#创建两张表 CREATE TABLE `tbl_emp` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `deptId` int(11) DEFAULT NULL, PRIMARY KEY (`id`) , KEY `fk_dept_id`(`deptId`) )ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8; CREATE TABLE `tbl_dept` ( `id` int(11) NOT NULL AUTO_INCREMENT, `deptName` varchar(30) DEFAULT NULL, `locAdd` varchar(40) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8;
#插入数据
INSERT INTO `tbl_emp` VALUES (1,‘z3‘,1),(2,‘z4‘,1),(3,‘z5‘,1),(4,‘w5‘,2),(5,‘w6‘,2),(6,‘s7‘,3),(7,‘s8‘,4),(8,‘s9‘,51);
INSERT INTO `tbl_dept` VALUES (1,‘RD‘,‘11‘),(2,‘HR‘,‘12‘),(3,‘MK‘,‘13‘),(4,‘MIS‘,‘14‘),(5,‘FD‘,‘15‘);
#未执行连接查询时,查出来的是笛卡尔积 select count(*) from tbl_emp e,tbl_dept d; #执行连接查询 #$1.第一张图:执行左连接查询 并且只要A的全部,不要B独有的部分 select * from tbl_emp e left join tbl_dept d on e.deptId=d.id; #$2.第二张图:执行内连接查询 并且只要AB共有的部分 select * from tbl_emp e inner join tbl_dept d on e.deptId=d.id; #$3.第三张图:执行右连接查询 并且只要B的全部,不要A独有的部分 select * from tbl_emp e right join tbl_dept d on e.deptId=d.id; #$4.第四张图:执行左连接查询 并且只要A独有的部分(加入where) select * from tbl_emp e left join tbl_dept d on e.deptId=d.id where d.id is null; #$5.第五张图:执行左连接查询 并且只要B独有的部分(加入where) select * from tbl_emp e right join tbl_dept d on e.deptId=d.id where e.id is null; #$6.第六张图:执行外连接查询 并且AB全要(加入union过滤) select * from tbl_emp e left join tbl_dept d on e.deptId=d.id -> union -> select * from tbl_emp e right join tbl_dept d on e.deptId=d.id; #$7.第七张图:执行外连接查询 并且只要A独有的部分和B独有的部分(加入union过滤) select * from tbl_emp e left join tbl_dept d on e.deptId=d.id where d.id is null -> union -> select * from tbl_emp e right join tbl_dept d on e.deptId=d.id where e.deptId is null;