亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

詳解MySQL中表的內(nèi)外連接

瀏覽:136日期:2023-08-28 20:27:10
目錄一、內(nèi)連接(表1 inner join 表2 on)1、顯示SMITH的名字和部門(mén)名稱二、外連接1、左外連接(表名1 left join 表名2 on)2、右外連接(表名1 right join 表名2)一、內(nèi)連接(表1 inner join 表2 on)

內(nèi)連接就是利用where子句對(duì)兩種表形成的笛卡爾積進(jìn)行篩選,之前博客寫(xiě)的查詢都是內(nèi)連接,也是在開(kāi)發(fā)過(guò)程中使用的最多的連接查詢。

語(yǔ)法:

select 字段 from 表1 inner join 表2 on 連接條件 and 其他條件;--或者select 字段 from 表1 inner join 表2 on 連接條件 where 條件 and 條件;1、顯示SMITH的名字和部門(mén)名稱--兩張數(shù)據(jù)表mysql> select* from emp;+--------+--------+-----------+------+---------------------+---------+---------+--------+| empno | ename | job | mgr | hiredate | sal | comm | deptno |+--------+--------+-----------+------+---------------------+---------+---------+--------+| 007369 | SMITH | CLERK | 7902 | 1980-12-17 00:00:00 | 800.00 | NULL | 20 || 007499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 | 30 || 007521 | WARD | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 | 30 || 007566 | JONES | MANAGER | 7839 | 1981-04-02 00:00:00 | 2975.00 | NULL | 20 || 007654 | MARTIN | SALESMAN | 7698 | 1981-09-28 00:00:00 | 1250.00 | 1400.00 | 30 || 007698 | BLAKE | MANAGER | 7839 | 1981-05-01 00:00:00 | 2850.00 | NULL | 30 || 007782 | CLARK | MANAGER | 7839 | 1981-06-09 00:00:00 | 2450.00 | NULL | 10 || 007788 | SCOTT | ANALYST | 7566 | 1987-04-19 00:00:00 | 3000.00 | NULL | 20 || 007839 | KING | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 | NULL | 10 || 007844 | TURNER | SALESMAN | 7698 | 1981-09-08 00:00:00 | 1500.00 | 0.00 | 30 || 007876 | ADAMS | CLERK | 7788 | 1987-05-23 00:00:00 | 1100.00 | NULL | 20 || 007900 | JAMES | CLERK | 7698 | 1981-12-03 00:00:00 | 950.00 | NULL | 30 || 007902 | FORD | ANALYST | 7566 | 1981-12-03 00:00:00 | 3000.00 | NULL | 20 || 007934 | MILLER | CLERK | 7782 | 1982-01-23 00:00:00 | 1300.00 | NULL | 10 |+--------+--------+-----------+------+---------------------+---------+---------+--------+14 rows in set (0.07 sec)mysql> select* from dept;+--------+------------+----------+| deptno | dname | loc |+--------+------------+----------+| 10 | ACCOUNTING | NEW YORK || 20 | RESEARCH | DALLAS || 30 | SALES | CHICAGO || 40 | OPERATIONS | BOSTON |+--------+------------+----------+4 rows in set (0.00 sec)

之前的寫(xiě)法:

mysql> select ename,dname from emp,dept where emp.deptno=dept.deptno and ename='SMITH';+-------+----------+| ename | dname |+-------+----------+| SMITH | RESEARCH |+-------+----------+1 row in set (0.01 sec)

標(biāo)準(zhǔn)的內(nèi)連接的寫(xiě)法:

mysql> select ename,dname from emp inner join dept on emp.deptno=dept.deptno and ename='SMITH';+-------+----------+| ename | dname |+-------+----------+| SMITH | RESEARCH |+-------+----------+1 row in set (0.00 sec)mysql> select ename,dname from emp inner join dept on emp.deptno=dept.deptno where ename='SMITH';+-------+----------+| ename | dname |+-------+----------+| SMITH | RESEARCH |+-------+----------+1 row in set (0.00 sec)二、外連接

外連接分為左外連接和右外連接。

1、左外連接(表名1 left join 表名2 on)

如果聯(lián)合查詢,左側(cè)的表完全顯示就是左外連接。

語(yǔ)法:

select 字段名 from 表名1 left join 表名2 on 連接條件;

整兩張表:

-- 學(xué)生表create table stu (id int, name varchar(30)); insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');--成績(jī)表create table exam (id int, grade int);insert into exam values(1, 56),(2,76),(11, 8);

1.1查詢所有學(xué)生的成績(jī),如果這個(gè)學(xué)生沒(méi)有成績(jī),也要將學(xué)生的個(gè)人信息顯示出來(lái)

學(xué)生表和成績(jī)表的id并不是一一對(duì)應(yīng)的,如果這里用內(nèi)連接,未在兩個(gè)表中出現(xiàn)的id字段將不會(huì)被篩選出來(lái):

mysql> select* from stu inner join exam on stu.id=exam.id;+------+------+------+-------+| id | name | id | grade |+------+------+------+-------+| 1 | jack | 1 | 56 || 2 | tom | 2 | 76 |+------+------+------+-------+2 rows in set (0.00 sec)

所以此處需要使用左外連接:

mysql> select* from stu left join exam on stu.id=exam.id;+------+------+------+-------+| id | name | id | grade |+------+------+------+-------+| 1 | jack | 1 | 56 || 2 | tom | 2 | 76 || 3 | kity | NULL | NULL || 4 | nono | NULL | NULL |+------+------+------+-------+4 rows in set (0.00 sec)2、右外連接(表名1 right join 表名2)

如果聯(lián)合查詢,右側(cè)的表完全顯示我們就說(shuō)是右外連接。

語(yǔ)法:

select 字段 from 表名1 right join 表名2 on 連接條件;

2.1對(duì)stu表和exam表聯(lián)合查詢,把所有的成績(jī)都顯示出來(lái),即使這個(gè)成績(jī)沒(méi)有學(xué)生與它對(duì)應(yīng),也要顯示出來(lái)

mysql> select exam.id,name,grade from stu right join exam on stu.id=exam.id;+------+------+-------+| id | name | grade |+------+------+-------+| 1 | jack | 56 || 2 | tom | 76 || 11 | NULL | 8 |+------+------+-------+3 rows in set (0.00 sec)

2.2列出部門(mén)名稱和這些部門(mén)的員工信息,同時(shí)列出沒(méi)有員工的部門(mén)

mysql> select * from emp right join dept on emp.deptno=dept.deptno order by emp.deptno asc;+--------+--------+-----------+------+---------------------+---------+---------+--------+--------+------------+----------+| empno | ename | job | mgr | hiredate | sal | comm | deptno | deptno | dname | loc |+--------+--------+-----------+------+---------------------+---------+---------+--------+--------+------------+----------+| NULL | NULL | NULL | NULL | NULL| NULL | NULL | NULL | 40 | OPERATIONS | BOSTON || 007839 | KING | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 | NULL | 10 | 10 | ACCOUNTING | NEW YORK || 007934 | MILLER | CLERK | 7782 | 1982-01-23 00:00:00 | 1300.00 | NULL | 10 | 10 | ACCOUNTING | NEW YORK || 007782 | CLARK | MANAGER | 7839 | 1981-06-09 00:00:00 | 2450.00 | NULL | 10 | 10 | ACCOUNTING | NEW YORK || 007902 | FORD | ANALYST | 7566 | 1981-12-03 00:00:00 | 3000.00 | NULL | 20 | 20 | RESEARCH | DALLAS || 007788 | SCOTT | ANALYST | 7566 | 1987-04-19 00:00:00 | 3000.00 | NULL | 20 | 20 | RESEARCH | DALLAS || 007876 | ADAMS | CLERK | 7788 | 1987-05-23 00:00:00 | 1100.00 | NULL | 20 | 20 | RESEARCH | DALLAS || 007369 | SMITH | CLERK | 7902 | 1980-12-17 00:00:00 | 800.00 | NULL | 20 | 20 | RESEARCH | DALLAS || 007566 | JONES | MANAGER | 7839 | 1981-04-02 00:00:00 | 2975.00 | NULL | 20 | 20 | RESEARCH | DALLAS || 007844 | TURNER | SALESMAN | 7698 | 1981-09-08 00:00:00 | 1500.00 | 0.00 | 30 | 30 | SALES | CHICAGO || 007521 | WARD | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 | 30 | 30 | SALES | CHICAGO || 007698 | BLAKE | MANAGER | 7839 | 1981-05-01 00:00:00 | 2850.00 | NULL | 30 | 30 | SALES | CHICAGO || 007900 | JAMES | CLERK | 7698 | 1981-12-03 00:00:00 | 950.00 | NULL | 30 | 30 | SALES | CHICAGO || 007499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 | 30 | 30 | SALES | CHICAGO || 007654 | MARTIN | SALESMAN | 7698 | 1981-09-28 00:00:00 | 1250.00 | 1400.00 | 30 | 30 | SALES | CHICAGO |+--------+--------+-----------+------+---------------------+---------+---------+--------+--------+------------+----------+15 rows in set (0.00 sec)

以上就是詳解MySQL中表的內(nèi)外連接的詳細(xì)內(nèi)容,更多關(guān)于MySQL內(nèi)外連接的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 好爽好深好猛好舒服视频上 | 国产乱码一区二区三区四区 | 善良的后裔完整视频在线观看 | 国内精品1区1区3区4区 | 一级全免费视频播放 | 18到20岁女人毛片一区 | 国产毛片网 | 欧美一级aⅴ毛片 | 国产日韩欧美亚洲综合 | 人妖与黑人做爰 | 日本精品久久久免费高清 | 青青青视频蜜桃一区二区 | 国产欧美一区视频在线观看 | 高h辣肉各种姿势爽文bl | 亚洲第一页在线播放 | 精品一精品国产一级毛片 | 日韩视频一区二区三区 | 在线免费观看小视频 | 99久久99这里只有免费的精品 | 久久国产经典 | 日韩精品午夜视频一区二区三区 | 中文字幕一区二区在线观看 | 国产一区欧美二区 | 手机看片自拍自拍自拍 | 特黄特色视频 | 1024在线看片 | 国产网站免费在线观看 | 欧美a一级 | 国产精品久久精品福利网站 | 青草免费视频 | 极品白嫩无套视频在线播放张悠雨 | 中文字幕成人网 | 欧美日韩国产一区二区三区 | 99精品国产一区二区青青牛奶 | 亚洲欧美在线综合一区二区三区 | 日本乱人伦片中文三区 | 日韩在线不卡 | 欧美日韩国产亚洲一区二区三区 | 国产精品每日在线观看男人的天堂 | 在线观看视频一区 | 亚洲成a人片在线观看www |