Heim >Datenbank >MySQL-Tutorial >So lösen Sie das Verbindungsabfrageproblem in MySql
Bei der Durchführung einer Mehrtabellen-Verbindungsabfrage müssen Sie die Tabelle angeben, zu der das Feld gehört. Dies kann die Abfrageeffizienz verbessern. Wenn Sie die Tabelle, zu der das Feld gehört, nicht angeben, kann dies die Datenbank verbessern sucht in jeder Tabelle nach dem Feld
e Feldname: Stellt dar, dass ein bestimmtes Feld der emp-Tabelle genommen wird
emp als e: Der Alias-Mechanismus der Tabelle, Sie können ihn weglassen und ihn direkt als schreiben emp e
Verbindungsabfrage: Es kann auch als tabellenübergreifende Abfrage bezeichnet werden. Dazu müssen mehrere Tabellen verknüpft werden, um die Daten gemeinsam abzufragen.
Verbinden Sie die emp-Tabelle und die dept-Tabelle, um die Daten abzufragen Nehmen Sie den Namen des Mitarbeiters aus der emp-Tabelle und nehmen Sie den Abteilungsnamen aus der dept-Tabelle Join-Abfragen
SQL92:
Nachteile von sql92: Die Struktur ist nicht klar, die Verbindungsbedingungen der Tabelle und die Bedingungen Für die weitere Filterung in der späteren Phase werden alle nach wo platziert
SQL99:
Tabelle A, linker äußerer Join, Tabelle B unter Assoziationsbedingung
Tabelle B, rechter äußerer Join, Tabelle A unter Assoziationsbedingung
Der linke Join soll auf der Tabelle links basieren und mit der Tabelle verglichen werden Auf der rechten Seite werden alle Ungleichungen angezeigt, die mit der linken Tabelle übereinstimmen, während diejenigen in der rechten Tabelle, die die Bedingungen erfüllen, angezeigt werden und diejenigen, die die Bedingungen nicht erfüllen, nicht angezeigt werden (die rechte Verknüpfung ist genau das Gegenteil). )
Die Funktion, die der linke Join ausführen kann, kann definitiv durch den rechten Join abgeschlossen werden Tabellen sind für die Abfrage verbunden und es sind keine Verbindungsbedingungen angegeben. Die endgültige Anzahl der Abfrageergebnisse beträgt zwei Tabelleneinträge. Das Produkt von Zahlen, dieses Phänomen wird genannt: Kartesisches Produktphänomen (entdeckt von Descartes, dies ist ein mathematisches Phänomen)
Da die Bedingungen gleich sind, werden sie Equi-Joins genannt (Daten mit gleichen Bedingungen verbinden)
--sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面 select e.ename,d.dname from emp e, dept d where e.deptno = d.deptno; --sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where select e.ename,d.dname from emp e --inner可以省略(带着inner可读性更好) (inner) join dept d on e.deptno = d.deptno;
Inner Join Self-Join
Eine Tabelle wird als zwei Zhang-Tabellen behandelt, emp e stellt die Mitarbeitertabelle dar , emp m stellt auch die Leitertabelle dar
--SQL92 select e.ename, m.ename from emp e, emp m where e.mgr=m.empno; --SQL99 select a.ename as '员工名', b.ename as '领导名' from emp e join emp m on e.mgr = m.empno;
Nicht äquivalente Verknüpfung der inneren Verknüpfung
--采用 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 (inner) join dept d on e.deptno=d.deptno where e.sal>2000;
select e.ename, e.sal, s.grade from emp e (inner) join salgrade s on e.sal between s.losal and s.hisal;
Outer Join: Beim Outer Join werden durch die Verbindung zweier Tabellen eine primäre und sekundäre Beziehung erstellt. Die Hauptabfrage sind die Daten der Primärtabelle und die der Sekundärtabelle Mit der Zuordnung abgefragt, das heißt, wenn die andere Partei keinen Datensatz hat, der mit meiner Haupttabelle übereinstimmt, ist das Standardgegenstück null und das äußere Schlüsselwort kann weggelassen werden
Linker äußerer Join : mit left t ist ein linker äußerer Join, was bedeutet, dass die Tabelle links vom Join-Schlüsselwort betrachtet wird. Die Haupttabelle besteht darin, alle Daten in dieser Tabelle abzufragen und die Tabelle rechts mit der Zuordnung abzufragen
**Hinweis: Jeder rechte Join hat einen linken Join und jeder linke Join hat eine rechte Verbindung**
查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来
--左连接 select a.ename as '员工名', b.ename as '领导名' from emp a left (outer) join emp b on a.mgr = b.empno; --右连接 select a.ename as '员工名', b.ename as '领导名' from emp b right (outer) join emp a on a.mgr = b.empno;
内连接:A表和B表连接,A和B两张表没有主次关系是平等的 , 查询时只是将能够匹配上连接条件的数据查询出来 , 即如果没有匹配的就查询不出来 , inner关键字可以省略
外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略
注意: 区分内外连接的办法是通过 right 和 left 关键字 , 不是通过 inner 和 outer 因为它们都可以省略 , 并且外连接的查询结果条数一定是大于等于内连接的查询结果条数
显示员工信息,并显示所属的部门名称
select e.ename,d.dname from emp e join dept d on e.deptno = d.deptno;
显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来
--外连接(右外连接) select e.ename,d.dname from emp e --outer是可以省略的,带着可读性强 --right代表什么:表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表 right (outer) join dept d on e.deptno = d.deptno; --外连接(左外连接) select e.ename,d.dname from dept d --outer是可以省略的,带着可读性强 left (outer) join emp e on e.deptno = d.deptno;
一条SQL中内连接和外连接可以混合 , 都可以出现
--表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐) --表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 d select ... from a join b on a和b的连接条件 join c on a和c的连接条件 right join d on a和d的连接条件
找出每个员工的部门名称以及工资等级,要求显示员工名、部门名、薪资、薪资等级
select e.ename,e.sal,d.dname,s.grade from emp e join dept d on e.deptno = d.deptno join salgrade s on e.sal between s.losal and s.hisal;
查询结果
+--------+---------+------------+-------+ | ename | sal | dname | grade | +--------+---------+------------+-------+ | SMITH | 800.00 | RESEARCH | 1 | | ALLEN | 1600.00 | SALES | 3 | | WARD | 1250.00 | SALES | 2 | | JONES | 2975.00 | RESEARCH | 4 | | MARTIN | 1250.00 | SALES | 2 | | BLAKE | 2850.00 | SALES | 4 | | CLARK | 2450.00 | ACCOUNTING | 4 | | SCOTT | 3000.00 | RESEARCH | 4 | | KING | 5000.00 | ACCOUNTING | 5 | | TURNER | 1500.00 | SALES | 3 | | ADAMS | 1100.00 | RESEARCH | 1 | | JAMES | 950.00 | SALES | 1 | | FORD | 3000.00 | RESEARCH | 4 | | MILLER | 1300.00 | ACCOUNTING | 2 | +--------+---------+------------+-------+
找出每个员工的部门名称以及工资等级,还有上级领导,要求显示员工名、领导名、部门名、薪资、薪资等级
select e.ename,e.sal,d.dname,s.grade,l.ename from emp e join dept d on e.deptno = d.deptno join salgrade s on e.sal between s.losal and s.hisal left join emp l on e.mgr = l.empno;
查询结果
+--------+---------+------------+-------+-------+ | ename | sal | dname | grade | ename | +--------+---------+------------+-------+-------+ | SMITH | 800.00 | RESEARCH | 1 | FORD | | ALLEN | 1600.00 | SALES | 3 | BLAKE | | WARD | 1250.00 | SALES | 2 | BLAKE | | JONES | 2975.00 | RESEARCH | 4 | KING | | MARTIN | 1250.00 | SALES | 2 | BLAKE | | BLAKE | 2850.00 | SALES | 4 | KING | | CLARK | 2450.00 | ACCOUNTING | 4 | KING | | SCOTT | 3000.00 | RESEARCH | 4 | JONES | | KING | 5000.00 | ACCOUNTING | 5 | NULL | | TURNER | 1500.00 | SALES | 3 | BLAKE | | ADAMS | 1100.00 | RESEARCH | 1 | SCOTT | | JAMES | 950.00 | SALES | 1 | BLAKE | | FORD | 3000.00 | RESEARCH | 4 | JONES | | MILLER | 1300.00 | ACCOUNTING | 2 | CLARK | +--------+---------+------------+-------+-------+
Das obige ist der detaillierte Inhalt vonSo lösen Sie das Verbindungsabfrageproblem in MySql. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!