..."/>
溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

join和on語句中select語句選擇公共列的區(qū)別

發(fā)布時(shí)間:2020-05-31 15:18:21 來源:網(wǎng)絡(luò) 閱讀:557 作者:逛街的刀客 欄目:關(guān)系型數(shù)據(jù)庫

  對多個(gè)表進(jìn)行join時(shí),在select語句中,如果使用using語句,則using語句中選中的列,在select語句中不能指定限定詞,否則會報(bào)ORA-25154

查看emp表

SQL> select * from emp;
EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
 7369 SMITH      CLERK      7902 1980/12/17     800.00               20
 7499 ALLEN      SALESMAN   7698 1981/2/20     1600.00    300.00     30
 7521 WARD       SALESMAN   7698 1981/2/22     1250.00    500.00     30
 7566 JONES      MANAGER    7839 1981/4/2      2975.00               20
 7654 MARTIN     SALESMAN   7698 1981/9/28     1250.00   1400.00     30
 7698 BLAKE      MANAGER    7839 1981/5/1      2850.00               30
 7782 CLARK      MANAGER    7839 1981/6/9      2450.00               10
 7788 SCOTT      ANALYST    7566 1987/4/19     3000.00               20
 7839 KING       PRESIDENT       1981/11/17    5000.00               10
 7844 TURNER     SALESMAN   7698 1981/9/8      1500.00      0.00     30
 7876 ADAMS      CLERK      7788 1987/5/23     1100.00               20
 7900 JAMES      CLERK      7698 1981/12/3      950.00               30
 7902 FORD       ANALYST    7566 1981/12/3     3000.00               20
 7934 MILLER     CLERK      7782 1982/1/23     1300.00               10

查看dept表

SQL> select * from dept;
DEPTNO DNAME          LOC
------ -------------- -------------
    10 ACCOUNTING     NEW YORK
    20 RESEARCH       DALLAS
    30 SALES          CHICAGO
    40 OPERATIONS     BOSTON

在select語句中使用using語句中指定的列,添加限定詞

SQL> select e.deptno,e.sal,d.dname from emp e join dept d using(deptno)
ORA-25154: USING 子句的列部分不能有限定詞

不添加時(shí)

SQL> select deptno,e.sal,d.dname from emp e join dept d using(deptno);
DEPTNO       SAL DNAME
------ --------- --------------
    10   2450.00 ACCOUNTING
    10   5000.00 ACCOUNTING
    10   1300.00 ACCOUNTING
    20   2975.00 RESEARCH
    20   3000.00 RESEARCH
    20   1100.00 RESEARCH
    20    800.00 RESEARCH
    20   3000.00 RESEARCH
    30   1250.00 SALES
    30   1500.00 SALES
    30   1600.00 SALES
    30    950.00 SALES
    30   2850.00 SALES
    30   1250.00 SALES
14 rows selected

而使用on時(shí),則必須指定限定詞才能正確的顯示,否則會報(bào)錯(cuò),提示deptno未能識別是哪個(gè)表,因?yàn)閐ept和emp表中都有deptno列

 select deptno,e.sal,d.dname from emp e join dept d on(e.deptno=d.deptno);
select deptno,e.sal,d.dname from emp e join dept d on(e.deptno=d.deptno)
ORA-00918: 未明確定義列

給deptno添加限定詞,就可以正常顯示了

SQL> select e.deptno,e.sal,d.dname from emp e join dept d on(e.deptno=d.deptno);
DEPTNO       SAL DNAME
------ --------- --------------
    10   2450.00 ACCOUNTING
    10   5000.00 ACCOUNTING
    10   1300.00 ACCOUNTING
    20   2975.00 RESEARCH
    20   3000.00 RESEARCH
    20   1100.00 RESEARCH
    20    800.00 RESEARCH
    20   3000.00 RESEARCH
    30   1250.00 SALES
    30   1500.00 SALES
    30   1600.00 SALES
    30    950.00 SALES
    30   2850.00 SALES
    30   1250.00 SALES
14 rows selected


在使用using時(shí),對select語句中的選定using指定的列時(shí),無需指定限定詞

在使用on時(shí),必須在select語句中對on語句條件中的條件列添加限定詞。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI