黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

MySQL數據庫概述及數據準備
MySQL數據庫常用命令
MySQL數據庫查看表結構
MySQL查詢字段
MySQL條件查詢
MySQL排序
MySQL函數
MySQL分組函數/聚合函數/多行處理函數
MySQL分組查詢
MySQL連接查詢
MySQL子查詢
MySQL UNION
MySQL中limit的用法
MySQL表
MySQL存儲引擎
MySQL事務
MySQL索引
MySQL視圖
MySQL DBA命令
MySQL數據庫設計的三大范式
MySQL數據庫練習題

MySQL連接查詢

SQL92語法

連接查詢:也可以叫跨表查詢,需要關聯多個表進行查詢。

● 顯示每個員工信息,并顯示所屬的部門名稱

select ename, dname from emp, dept;

SQL> select ename, dname from emp, dept;

 

ENAME      DNAME

---------- --------------

SMITH      ACCOUNTING

ALLEN      ACCOUNTING

WARD       ACCOUNTING

JONES      ACCOUNTING

MARTIN     ACCOUNTING

BLAKE      ACCOUNTING

CLARK      ACCOUNTING

SCOTT      ACCOUNTING

KING       ACCOUNTING

TURNER     ACCOUNTING

ADAMS      ACCOUNTING

JAMES      ACCOUNTING

FORD       ACCOUNTING

MILLER     ACCOUNTING

SMITH      RESEARCH

ALLEN      RESEARCH

WARD       RESEARCH

JONES      RESEARCH

MARTIN     RESEARCH

BLAKE      RESEARCH

CLARK      RESEARCH

SCOTT      RESEARCH

KING       RESEARCH

TURNER     RESEARCH

ADAMS      RESEARCH

JAMES      RESEARCH

FORD       RESEARCH

MILLER     RESEARCH

SMITH      SALES

ALLEN      SALES

WARD       SALES

JONES      SALES

MARTIN     SALES

BLAKE      SALES

CLARK      SALES

SCOTT      SALES

KING       SALES

TURNER     SALES

ADAMS      SALES

JAMES      SALES

FORD       SALES

MILLER     SALES

SMITH      OPERATIONS

ALLEN      OPERATIONS

WARD       OPERATIONS

JONES      OPERATIONS

MARTIN     OPERATIONS

BLAKE      OPERATIONS

CLARK      OPERATIONS

SCOTT      OPERATIONS

KING       OPERATIONS

TURNER     OPERATIONS

ADAMS      OPERATIONS

JAMES      OPERATIONS

FORD       OPERATIONS

MILLER     OPERATIONS

 

已選擇56行。

以上輸出,不正確,輸出了56條數據,其實就是兩個表記錄的成績,這種情況我們稱為:“笛卡兒乘積”,出現錯誤的原因是:沒有指定連接條件。

指定連接條件

select emp.ename, dept.dname from emp, dept where

emp.deptno=dept.deptno;


也可以使用別名


select e.ename, d.dname from emp e, dept d where e.deptno=d.deptno;

以上結果輸出正確,因為加入了正確的連接條件;

以上查詢也稱為 “內連接”,只查詢相等的數據(連接條件相等的數據)。

● 取得員工和所屬的領導的姓名

select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;

SQL> select * from emp;(普通員工)

 

     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO

---------- ---------- --------- ---------- -------------- ---------- ---------- ----------

      7369 SMITH      CLERK           7902 17-12月-80            800                    20

      7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30

      7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30

      7566 JONES      MANAGER         7839 02-4月 -81           2975                    20

      7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400         30

      7698 BLAKE      MANAGER         7839 01-5月 -81           2850                    30

      7782 CLARK      MANAGER         7839 09-6月 -81           2450                    10

      7788 SCOTT      ANALYST         7566 19-4月 -87           3000                    20

      7839 KING       PRESIDENT            17-11月-81           5000                    10

      7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30

      7876 ADAMS      CLERK           7788 23-5月 -87           1100                    20

      7900 JAMES      CLERK           7698 03-12月-81            950                    30

      7902 FORD       ANALYST         7566 03-12月-81           3000                    20

      7934 MILLER     CLERK           7782 23-1月 -82           1300                    10

 

已選擇14行。

 

SQL> select * from emp;(管理者)

 

     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO

---------- ---------- --------- ---------- -------------- ---------- ---------- ----------

      7369 SMITH      CLERK           7902 17-12月-80            800                    20

      7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30

      7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30

      7566 JONES      MANAGER         7839 02-4月 -81           2975                    20

      7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400         30

      7698 BLAKE      MANAGER         7839 01-5月 -81           2850                    30

      7782 CLARK      MANAGER         7839 09-6月 -81           2450                    10

      7788 SCOTT      ANALYST         7566 19-4月 -87           3000                    20

      7839 KING       PRESIDENT            17-11月-81           5000                    10

      7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30

      7876 ADAMS      CLERK           7788 23-5月 -87           1100                    20

      7900 JAMES      CLERK           7698 03-12月-81            950                    30

      7902 FORD       ANALYST         7566 03-12月-81           3000                    20

      7934 MILLER     CLERK           7782 23-1月 -82           1300                    10

 

已選擇14行。

 

SQL> select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;

 

ENAME      ENAME

---------- ----------

SMITH      FORD

ALLEN      BLAKE

WARD       BLAKE

JONES      KING

MARTIN     BLAKE

BLAKE      KING

CLARK      KING

SCOTT      JONES

TURNER     BLAKE

ADAMS      SCOTT

JAMES      BLAKE

FORD       JONES

MILLER     CLARK

 

已選擇13行。

以上稱為“自連接”,只有一張表連接,具體的查詢方法,把一張表看作兩張表即可,如以上示例:第一個表emp e代碼了員工表,emp m代表了領導表,相當于員工表和部門表一樣

SQL99語法

● (內連接)顯示薪水大于2000的員工信息,并顯示所屬的部門名稱

采用SQL92語法:

采用SQL92語法:
select e.ename, e.sal, d.dname from emp e, dept d where e.deptno=d.deptno and  e.sal > 2000;
采用SQL99語法:
select e.ename, e.sal, d.dname from emp e join dept d on e.deptno=d.deptno where e.sal>2000;
或
select e.ename, e.sal, d.dname from emp e inner join dept d on e.deptno=d.deptno where e.sal>2000;
在實際中一般不加inner關鍵字

Sql92語法和sql99語法的區別:99語法可以做到表的連接和查詢條件分離,特別是多個表進行連接的時候,會比sql92更清晰。

●(外連接)顯示員工信息,并顯示所屬的部門名稱,如果某一個部門沒有員工,那么該部門也必須顯示出來

右連接:
select e.ename, e.sal, d.dname from emp e right join dept d on e.deptno=d.deptno;
左連接:
select e.ename, e.sal, d.dname from dept d left join emp e on e.deptno=d.deptno;
以上兩個查詢效果相同

連接分類:

1、內鏈接

* 表1 inner join 表2 on 關聯條件

* 做連接查詢的時候一定要寫上關聯條件

* inner 可以省略

2、外連接

● 左外連接

* 表1 left outer join 表2 on 關聯條件

* 做連接查詢的時候一定要寫上關聯條件

* outer 可以省略*

● 右外連接

* 表1 right outer join 表2 on 關聯條件

* 做連接查詢的時候一定要寫上關聯條件

* outer 可以省略

*左外連接(左連接)和右外連接(右連接)的區別:

*左連接以左面的表為準和右邊的表比較,和左表相等的不相等都會顯示出來,右表符合條件的顯示,不符合條件的不顯示

*右連接恰恰相反,以上左連接和右連接也可以加入outer關鍵字,但一般不建議這種寫法,如:

select e.ename, e.sal, d.dname from emp e right outer join dept d on e.deptno=d.deptno;

select e.ename, e.sal, d.dname from dept d left outer join emp e on e.deptno=d.deptno;

左連接能完成的功能右連接一定可以完成。

全部教程
主站蜘蛛池模板: 欧美福利第一页 | 久久女同互慰一区二区三区 | 又黄又爽又猛的视频免费 | 乱仑小说日本aⅴ | 美女视频黄是免费的 | 在线免费观看污网站 | 亚洲精品第1页 | 色偷偷人人澡人人爽人人模 | 国产无圣光高清一区二区 | 亚洲三级影视 | 久久综合狠狠综合狠狠 | 成人羞羞视频在线观看 | 免费一级欧美在线观看视频片 | 亚洲国产欧洲 | 欧美亚洲欧美区 | ww亚洲ww在线观看国产 | 老色网站| 黄色aa毛片 | 色爱区综合激情五月综合色 | 欧美日韩视频一区二区三区 | 看片午夜 | 日本一区二区在线播放 | 九九九九九九精品免费 | 久久精品动漫网一区二区 | 一本大道香蕉中文在线高清 | 日韩免费一级a毛片在线播放一级 | 一级大黄美女免费播放 | 久久久午夜影院 | 日本三级香港三级三级人 | 日本黄色片网址 | 男女很黄很色床视频网站免 | 亚洲精品综合久久 | 99激情| 在线免费视频网站 | 亚洲日本va中文字幕在线不卡 | 免费观看18视频网站 | 午夜成私人影院在线观看 | 无收费看污网站 | 老子影院午夜伦不卡不四虎卡 | 乱亲h女 小说 | 国产aa大片 |