付费下载
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Mysql 的左连接与右连接区别1.SQL LEFT JOIK 键字(table_name2)(table_name1)LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 中没有匹配的行。2.SQL RIGHT JOIN关键字RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 中没有匹配的行。3.在 Mysql 中的 DevDB 中创建两个表Create Table departmentCREATE TABLE 'department' ('ID' int(11) NOT NUL
2、L AUTO_INCREMENT,'CODE' varchar(100) DEFAULT NULL,'NAME' varchar(200) DEFAULT NULL,PRIMARY KEY ('ID') ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8Create Table jobCREATE TABLE 'job' ('id' int(11) NOT NULL AUTO_INCREMENT, 'FirstName' varchar(32) D
3、EFAULT NULL, 'LastName' varchar(32) DEFAULT NULL, 'LoginName' varchar(32) DEFAULT NULL, 'dep_id' int(11) DEFAULT NULL, PRIMARY KEY ('id') ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 4.在 department 表和 Job 表中插入数据5in sert into 'de partme nt' ('ID'
4、, 'CODE', 'NAME') values('1','Java R&D'Java R&D');in sert into 'de partme nt' ('ID', 'CODE', 'NAME') values(2,'Mysql R&D','Mysql R&D');insert into 'department' ('ID', 'CODE', &
5、#39;NAME') values('3','Interface R&D','Interface R&D'); insert into 'department' ('ID', 'CODE', 'NAME') values('4','Android R&D','Android R&D'); insert into 'department' ('ID', 'CO
6、DE', 'NAME') values('5','IOS R&D','IOS R&D');values('3','Garfield','Wang','Wang','3');insert into 'Job' ('id', 'FirstName',','Jone','Jone',NULL);insert into 'Job' (
7、'id', 'FirstName', 'LastName', 'LoginName', 'dep_id') values('5','Westlife',' 西城 男孩 ','Westlife','8');department 表数据ID1CODE NAMEJava R&DJava R&D'LastName','LoginName', 'dep_id') values(
8、9;4','哆啦 A 梦insertinto'Job'('id','FirstName','LastName','LoginName','dep_id')values('1','Peter','Qiu','Qiu','1');insertinto'Job'('id','FirstName','LastName','LoginName&
9、#39;,'dep_id')values('2','Tom','Lee','Lee','2');insertinto'Job'('id','FirstName','LastName','LoginName','dep_id')2345Job 表数据id12345FirstNamePeter QiuTomLee LeeGarfield Wang Wang 哆啦 A 梦 JoneJone(NULL)LastN
10、ameQiu 12LoginName dep_idWestlife 西城男孩 Westlife 8Mysql R&D Mysql R&DInterface R&D Interface R&D Android R&D Android R&DIOS R&D IOS R&D5.以Job表进行左连接(left join)123/* 以 Job 表进行左连接, 此时数据主要以 Job 表为主,关联 department 表,如果 Job 的 dep_id 为 null 或者在 department 表中无对应的 Id 匹配对应的字段自动填充
11、 null*/SELECT * FROM Job table_name1 table_name1.'dep_id'= table_name2.'ID'LEFT JOIN department table_name2 ON查出来的数据idFirstNameLastName LoginName dep_idJava R&DJava R&D Mysql R&D 3 Interface R&D (NULL) (NULL)Qiu 1122 Mysql R&DGarfield WangWang 3哆啦 A 梦 JoneJone(NUL
12、L) Westlife 西城男孩 WestlifePeter QiuTomLee Lee56.以Job表进行右连接(right join)ID CODE NAMEInterface R&D (NULL)8 (NULL) (NULL) (NULL)3/* 以 Job 表进行右连接, 此时数据主要以 department 表为主,关联 Job 表,如果 Job 的 dep_id 为 null 或者在 department 表中无对应的 Id 匹配对应的字段自动填充 null*/RIGHT JOIN department table_name2 ONSELECT * FROM Job tab
13、le_name1table_ namel.'de p_id'= table_ name2.'ID' 查出来的数据id1FirstNamePeter QiuLastNameQiu 1 1LoginName dep_idJava R&DJava R&DID CODE NAME2 2 Mysql R&DWang 3TomLee LeeGarfield Wang(NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL)Mysql R&D3 Interface R&DInterfa
14、ce R&D(NULL) 4 Android R&D Android R&D(NULL) 5IOS R&D IOS R&D23脚本如下:drop table table1;CREATE TABLE 'a ndrew'.'tablel'('name' VARCHAR(32) NOT NULL,'city' VARCHAR(32) NOT NULL)ENGINE = MyISAM;insert into TABLE1(name, city) values ('Person A',
15、 'BJ'); insert into TABLE1(name, city) values ('Person B', 'BJ'); insert into TABLE1(name, city) values ('Person C', 'SH'); insert into TABLE1(name, city) values ('Person D', 'SZ'); commit;drop table table2;CREATE TABLE 'andrew'.'ta
16、ble2'('name' VARCHAR(32) NOT NULL,'city' VARCHAR(32) NOT NULL)ENGINE = MyISAM;insert into TABLE2(name, city) values ('Person W', 'BJ'); insert into TABLE2(name, city) values ('Person X', 'SH'); insert into TABLE2(name, city) values ('Person Y
17、39;, 'SH'); insert into TABLE2(name, city) values ('Person Z', 'NJ'); commit;1. 外连接-左连接结果 table1 居左,故谓之左连接。这种情况下,以 table1 为主,即 table1 中的所有记录均会被列 出。有一下三种情况:a. 对于 table1 中的每一条记录对应的城市如果在 table2 中也恰好存在而且刚好只有一条, 那么就会在返回的结果中形成一条新的记录。如上面 Person A和Person B对应的情况。table2 中也恰好存在而且有 N 条,那
18、么就Person C对应的情况。table2 中不存在,那么就会在返回的结果b. 对于 table1 中的每一条记录对应的城市如果在 会在返回的结果中形成 N 条新的记录。如上面的c. 对于 table1 中的每一条记录对应的城市如果在 中形成一条条新的记录,且该记录的右边全部NULL。如上面的Person D对应的情况。不符合上面三条规则的记录不会被列出。2. 外连接-右连接结果 table2 居右,故谓之右连接。这种情况下,以 table2 为主,即 table2 中的所有记录均会被列 出。有一下三种情况:a. 对于 table2 中的每一条记录对应的城市如果在 table1 中也恰好存在而且刚好只有一条, 那么就会在返回的结果中形成一条新的记录。如上面Person X和Person Y对应的情况。table1 中也恰好存在而且有 N 条,那么就 Per
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025 高中信息技术信息系统在农村水利灌溉设施远程监控与管理中的应用课件
- 部门协作支持请求函8篇范本
- 高校教务系统操作规范手册
- 雨课堂学堂在线学堂云《教育数学概论(成都师范学院)》单元测试考核答案
- 企业员工激励系统构建实施方案指南
- 科研教育合作协定书诚信保证条款承诺书范文3篇
- 确认服务范围回复函(4篇)
- 2025 高中信息技术数据结构的队列在分布式消息系统容错机制中的应用课件
- 糖尿病患者心理支持与咨询技巧
- 餐饮门店从业工作人员健康检查制度
- TCCIIA0004-2024精细化工产品分类
- 2026年内蒙古自治区招收事业编制行政执法人员1991人参考笔试试题及答案解析
- 质量环境及职业健康安全三体系风险和机遇识别评价分析及控制措施表(包含气候变化)
- 农业种植基地合作开发和利益分配协议
- 湖北2025年地生中考试卷及答案
- 2025年高职汽车检测与维修技术(汽车检测)试题及答案
- 2025年11月近期典型事故案例警示教育
- 卵巢肿瘤病例讨论课件
- 2025年时事热点政治题及参考答案(满分必刷)
- 2026年国网内蒙古东部电力校园招聘(工程管理类)复习题及答案
- 2025年大学《老年学-老年学概论》考试备考试题及答案解析
评论
0/150
提交评论