




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Mysql之inner join,left join,right join详解文章分类:PHP编程首先借用官方的解释下:inner join(等值连接):只返回两个表中联结字段相等的行;left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录;right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录。比如我们有xs、cj两个表xs表 cj表- -id name id score1 张三 1 962 李四 2 80 3 86 Sql代码 1 SELECT * FROM xs INNER JOIN cj ON xs.id = cj.id 返回-id name id score1 张三 1 962 李四 2 80- Sql代码 2 SELECT * FROM xs LEFT JOIN cj ON xs.id = cj.id 返回-id name id score1 张三 1 962 李四 2 80- Sql代码 3 SELECT * FROM xs RIGHT JOIN cj ON xs.id = cj.id 返回id name id score1 张三 1 962 李四 2 80NULL NULL 3 86 其中还有inner join还有另外一种写法,两者是等价的,都是等值连接 Sql代码 4 SELECT * FROM xs,cj WHERE xs.id = cj.id mysql多表连接查询inner join, left join , right join ,full join ,cross join关键字: mysql inner join left join right join full join cross joininner join,full outer join,left join,right jion内部连接 inner join 两表都满足的组合full outer 全连 两表相同的组合在一起,A表有,B表没有的数据(显示为null),同样B表有A表没有的显示为(null)A表 left join B表 左连,以A表为基础,A表的全部数据,B表有的组合。没有的为nullA表 right join B表 右连,以B表为基础,B表的全部数据,A表的有的组合。没有的为null查询分析器中执行:-建表table1,table2:create table table1(id int,name varchar(10)create table table2(id int,score int)insert into table1 select 1,leeinsert into table1 select 2,zhanginsert into table1 select 4,wanginsert into table2 select 1,90insert into table2 select 2,100insert into table2 select 3,70如表-table1|table2|-idname|idscore|1lee|190|2zhang|2100|4wang|370|-以下均在查询分析器中执行一、外连接1.概念:包括左向外联接、右向外联接或完整外部联接2.左连接:left join 或 left outer join(1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。(2)sql 语句select * from table1 left join table2 on table1.id=table2.id-结果-idnameidscore-1lee1902zhang21004wangNULLNULL-注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示3.右连接:right join 或 right outer join(1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。(2)sql 语句select * from table1 right join table2 on table1.id=table2.id-结果-idnameidscore-1lee1902zhang2100NULLNULL370-注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示4.完整外部联接:full join 或 full outer join(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。(2)sql 语句select * from table1 full join table2 on table1.id=table2.id-结果-idnameidscore-1lee1902zhang21004wangNULLNULLNULLNULL370-注释:返回左右连接的和(见上左、右连接)二、内连接1.概念:内联接是用比较运算符比较要联接列的值的联接2.内连接:join 或 inner join3.sql 语句select * from table1 join table2 on table1.id=table2.id-结果-idnameidscore-1lee1902zhang2100-注释:只返回符合条件的table1和table2的列4.等价(与下列执行效果相同)A:select a.*,b.* from table1 a,table2 b where a.id=b.idB:select * from table1 cross join table2 where table1.id=table2.id (注:cross join后加条件只能用where,不能用on)三、交叉连接(完全)1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)2.交叉连接:cross join (不带条件where.)3.sql语句select * from table1 cross join table2-结果-idnameids
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 新型储能材料生产线项目节能评估报告
- 2025年福建美术学科真题及答案
- 2025年血站采血考试试题及答案
- 灌云县2024-2025学年第一学期四年级数学期末学业评价题库及答案
- 拆除过程中材料搬运与堆放方案
- 离异父母子女抚养费支付及家庭财产分配调整合同
- 离婚房产分割及赡养费支付协议范本
- 沙盘模拟经营试题及答案
- 主题公园舞台租赁与互动体验项目合作协议
- 航空安全员上岗培训及答案
- GB 42590-2023民用无人驾驶航空器系统安全要求
- 《精神科护理学》练习题及答案
- 护士执业注册体检表
- 直升机结构与系统版
- 新生儿疾病诊疗规范诊疗指南诊疗常规2022版
- 外科学 胃十二指肠疾病
- 《智能投顾 大数据智能驱动投顾创新》读书笔记思维导图
- 职工自愿放弃社会保险协议
- 高中英语Unit5Firstaid文章BasicFirstAid人教版必修五
- 2021北京昌平初二(上)期中数学(A)(教师版)
- SH/T 0356-1996燃料油
评论
0/150
提交评论