前言

设想场景:小白初入职场,看到很多数据库的代码发现都不分明,急哭小白了,急急忙忙的去百度,收集到的材料很多,也很迷,乌七八糟的都是

虫虫:为了不便小白 虫虫把关联表的查问形式总结了

关联查问品种

等值连贯、天然连贯、内连贯、自连贯、左外连贯右外连贯、全连贯

试验用表

本次用到的表有test表和user表,上面是两个表的sql代码

SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for test-- ----------------------------DROP TABLE IF EXISTS `test`;CREATE TABLE `test`  (  `location_id` int(11) DEFAULT NULL,  `location_name` varchar(20) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,  INDEX `name_index`(`location_name`) USING BTREE) ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Compact;-- ------------------------------ Records of test-- ----------------------------INSERT INTO `test` VALUES (1, 'UK');INSERT INTO `test` VALUES (2, 'US');INSERT INTO `test` VALUES (3, 'Chain');SET FOREIGN_KEY_CHECKS = 1;
SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for user-- ----------------------------DROP TABLE IF EXISTS `user`;CREATE TABLE `user`  (  `id` int(11) NOT NULL,  `username` varchar(255) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,  `birthday` varchar(255) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,  `sex` varchar(255) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,  `location_name` varchar(255) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL) ENGINE = InnoDB CHARACTER SET = latin1 COLLATE = latin1_swedish_ci ROW_FORMAT = Compact;-- ------------------------------ Records of user-- ----------------------------INSERT INTO `user` VALUES (1, 'Tom', '1', 'boy', 'UK');INSERT INTO `user` VALUES (2, 'Bob', '2', 'boy', 'US');INSERT INTO `user` VALUES (4, 'Worm', '4', 'boy', 'Chain');SET FOREIGN_KEY_CHECKS = 1;

等值连贯

应用”=”关系将表连接起来的查问,其查问后果中列出被连贯表中的所有列,包含其中的反复列

select * from test t,user u where t.location_id=u.id

后果:

location_idlocation_nameidusernamebirthdaysexlocation_name(1)
1UK1Tom1boyUK
2US2Bob2boyUS

天然连贯

进行天然连贯运算要求两个表有独特属性(列),天然连贯运算的后果表是在参加操作的两个表的独特属性上进行等值连贯后,再去除反复的属性后所得的新表。

1.等值连贯中不要求属性值完全相同,而天然连贯要求两个关系中进行比拟的必须是雷同的属性组(属性名能够不同),即要求必须有雷同的值域。

2.等值连贯不将反复属性去掉,而天然连贯去掉反复属性,也能够说,天然连贯是去掉反复列的等值连贯。

select * from test t natural join user u 

后果:

location_idlocation_nameidusernamebirthdaysex
UK11Tom1boy
US22Bob2boy
Chain34Worm4boy

内连贯

内连贯与等值连贯是同一件事,只是内连贯是由SQL 1999规定定的书写形式。两个说的是一码事。

select * from test t join user u on t.location_id=u.id 

你能够能够加上inner

select * from test t inner join user u on t.location_id=u.id

后果:

location_idlocation_nameidusernamebirthdaysexlocation_name(1)
1UK1Tom1boyUK
2US2Bob2boyUS

自连贯

自连贯作为一种特例,能够将一个表与它本身进行连贯,称为自连贯。若要在一个表中查找具备雷同列值的行,则能够应用自连贯。应用自连贯时需为表指定两个别名,且对所有列的援用均要用别名限定。

select * from user t  join user u on t.sex=u.sex

后果:

idusernamebirthdaysexlocation_nameid(1)username(1)birthday(1)sex(1)location_name(1)
1Tom1boyUK1Tom1boyUK
2Bob2boyUS1Tom1boyUK
4Worm4boyChain1Tom1boyUK
1Tom1boyUK2Bob2boyUS
2Bob2boyUS2Bob2boyUS
4Worm4boyChain2Bob2boyUS
1Tom1boyUK4Worm4boyChain
2Bob2boyUS4Worm4boyChain
4Worm4boyChain4Worm4boyChain

左外连贯

左向外联接的后果集包含 left outer子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的后果集行中右表的所有抉择列表列均为空值。

select * from test t  left join user u on t.location_id=u.id

后果:

location_idlocation_nameidusernamebirthdaysexlocation_name(1)
1UK1Tom1boyUK
2US2Bob2boyUS
3Chain

右外连贯

右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

select t.*,u.* from test t  right join user u on t.location_id=u.id

后果:

location_idlocation_nameidusernamebirthdaysexlocation_name(1)
1UK1Tom1boyUK
2US2Bob2boyUS
4Worm4boyChain

全连贯(Mysql不反对)

残缺内部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的抉择列表列蕴含空值。如果表之间有匹配行,则整个后果集行蕴含基表的数据值。

select t.*,u.* from test t  full join user u on t.location_id=u.id

后果:

location_idlocation_nameidusernamebirthdaysexlocation_name(1)
1UK1Tom1boyUK
2US2Bob2boyUS
3Chain
4Worm4boyChain

创作不易,如果本篇文章能帮忙到你,请给予反对,赠人玫瑰,手有余香,虫虫蟹蟹观众姥爷了