suchen
HeimDatenbankMySQL-TutorialSo lösen Sie das Verbindungsabfrageproblem in MySql

    Verbindungsabfrage

    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

    Klassifizierung basierend auf dem Alter der Grammatik

    SQL92:

    Die Grammatik, die 1992 erschien

    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:
      Die 1999 erschienene Syntax (Schlüssellernen)
    • sql99 Vorteile: Tabellenverbindungsbedingungen und Abfragen Bedingte Trennung, wenn weitere Filterung erforderlich ist Fügen Sie nach der Verbindung weiter hinzu, wo später, es wird klarer sein, wenn Sie mehrere Tabellen verbinden , inner kann weggelassen und im Allgemeinen nicht hinzugefügt werden Hinzufügen

    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)

      Vermeiden Sie das Kartesisches Produktphänomen: Fügen Sie Verbindungsbedingungen hinzu, wenn Sie mehrere Tabellen verbinden, und Datensatzdatensätze, die diese Bedingung erfüllen, wurden herausgefiltert Basierend auf den Verbindungsbedingungen gefiltert
    • Aus dem kartesischen Produktphänomen kann geschlossen werden, dass die Effizienz der Tabelle umso geringer ist. Versuchen Sie, die Anzahl der Tabellenverbindungen zu vermeiden innere Verknüpfungen

    Da die Bedingungen gleich sind, werden sie Equi-Joins genannt (Daten mit gleichen Bedingungen verbinden)

    • Fragen Sie den Namen der Abteilung ab, in der sich jeder Mitarbeiter befindet, zeigen Sie den Namen und die Abteilung des Mitarbeiters an

    • emp e und Dept d-Tabellen sind verbunden, die Verbindungsbedingung lautet: e.deptno = d.deptno
    • 	--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

    • Da es nur eine Tabellenverbindung gibt, besteht die spezifische Abfragemethode darin, eine Tabelle als zwei Tabellen zu behandeln und eine Verbindung herzustellen sich selbst, sodass es sich um eine Selbstverknüpfung handelt
    • Um den Vorgesetzten des Mitarbeiters abzufragen, müssen der Name des Mitarbeiters und der entsprechende Name des Leiters angezeigt werden
    • Eine Tabelle wird als zwei Zhang-Tabellen behandelt, emp e stellt die Mitarbeitertabelle dar , emp m stellt auch die Leitertabelle dar

    • Verbindungsbedingungen: e.mgr = m.empno Führungsnummer des Mitarbeiters = Mitarbeiternummer des Leiters
    --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

    Da die Verbindungsbedingung keine Äquivalenzbeziehung ist, ist sie wird als nichtäquivalente Verbindung bezeichnet

    Zeigen Sie Mitarbeiterinformationen mit einem Gehalt von mehr als 2000 an und zeigen Sie den Namen der Abteilung an, zu der sie gehören

    --采用 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;
    • Finden Sie die Gehaltsstufe jedes Mitarbeiters heraus und fordern Sie die Anzeige der Mitarbeiter an Name, Gehalt, Gehaltsstufe

      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
    • 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;

    So lösen Sie das Verbindungsabfrageproblem in MySql

    显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来

    --外连接(右外连接)
    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;

    So lösen Sie das Verbindungsabfrageproblem in MySql

    多表连接

    一条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!

    Stellungnahme
    Dieser Artikel ist reproduziert unter:亿速云. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
    Erläutern Sie den InnoDB -Pufferpool und seine Bedeutung für die Leistung.Erläutern Sie den InnoDB -Pufferpool und seine Bedeutung für die Leistung.Apr 19, 2025 am 12:24 AM

    InnoDbbufferpool reduziert die Scheiben -E/A durch Zwischenspeicherung von Daten und Indizieren von Seiten und Verbesserung der Datenbankleistung. Das Arbeitsprinzip umfasst: 1. Daten lesen: Daten von Bufferpool lesen; 2. Daten schreiben: Schreiben Sie nach der Änderung der Daten an Bufferpool und aktualisieren Sie sie regelmäßig auf Festplatte. 3. Cache -Management: Verwenden Sie den LRU -Algorithmus, um Cache -Seiten zu verwalten. 4. Lesemechanismus: Last benachbarte Datenseiten im Voraus. Durch die Größe des Bufferpool und die Verwendung mehrerer Instanzen kann die Datenbankleistung optimiert werden.

    MySQL gegen andere Programmiersprachen: Ein VergleichMySQL gegen andere Programmiersprachen: Ein VergleichApr 19, 2025 am 12:22 AM

    Im Vergleich zu anderen Programmiersprachen wird MySQL hauptsächlich zum Speichern und Verwalten von Daten verwendet, während andere Sprachen wie Python, Java und C für die logische Verarbeitung und Anwendungsentwicklung verwendet werden. MySQL ist bekannt für seine hohe Leistung, Skalierbarkeit und plattformübergreifende Unterstützung, die für Datenverwaltungsanforderungen geeignet sind, während andere Sprachen in ihren jeweiligen Bereichen wie Datenanalysen, Unternehmensanwendungen und Systemprogramme Vorteile haben.

    Lernen von MySQL: Eine Schritt-für-Schritt-Anleitung für neue BenutzerLernen von MySQL: Eine Schritt-für-Schritt-Anleitung für neue BenutzerApr 19, 2025 am 12:19 AM

    MySQL ist es wert, gelernt zu werden, da es sich um ein leistungsstarkes Open -Source -Datenbankverwaltungssystem handelt, das für Datenspeicher, Verwaltung und Analyse geeignet ist. 1) MySQL ist eine relationale Datenbank, die SQL zum Betrieb von Daten verwendet und für die strukturierte Datenverwaltung geeignet ist. 2) Die SQL -Sprache ist der Schlüssel zur Interaktion mit MySQL und unterstützt CRUD -Operationen. 3) Das Arbeitsprinzip von MySQL umfasst Client/Server -Architektur, Speicher -Engine und Abfrageoptimierer. 4) Die grundlegende Nutzung umfasst das Erstellen von Datenbanken und Tabellen, und die erweiterte Verwendung umfasst das Verbinden von Tabellen mit dem Join. 5) Zu den häufigen Fehlern gehören Syntaxfehler und Erlaubnisprobleme, und die Debugging -Fähigkeiten umfassen die Überprüfung der Syntax und die Verwendung von Erklärungskenntnissen. 6) Die Leistungsoptimierung umfasst die Verwendung von Indizes, die Optimierung von SQL -Anweisungen und die regelmäßige Wartung von Datenbanken.

    MySQL: Wesentliche Fähigkeiten für Anfänger zu meisternMySQL: Wesentliche Fähigkeiten für Anfänger zu meisternApr 18, 2025 am 12:24 AM

    MySQL ist für Anfänger geeignet, um Datenbankfähigkeiten zu erlernen. 1. Installieren Sie MySQL Server- und Client -Tools. 2. Verstehen Sie grundlegende SQL -Abfragen, wie z. B. SELECT. 3.. Stammdatenoperationen: Daten erstellen, Daten einfügen, aktualisieren und löschen. 4. Lernen Sie fortgeschrittene Fähigkeiten: Unterabfragen und Fensterfunktionen. 5. Debugging und Optimierung: Überprüfen Sie die Syntax, verwenden Sie Indizes, vermeiden Sie die Auswahl*und verwenden Sie die Grenze.

    MySQL: Strukturierte Daten und relationale DatenbankenMySQL: Strukturierte Daten und relationale DatenbankenApr 18, 2025 am 12:22 AM

    MySQL verwaltet strukturierte Daten effizient durch Tabellenstruktur und SQL-Abfrage und implementiert Inter-Tisch-Beziehungen durch Fremdschlüssel. 1. Definieren Sie beim Erstellen einer Tabelle das Datenformat und das Typ. 2. Verwenden Sie fremde Schlüssel, um Beziehungen zwischen Tabellen aufzubauen. 3.. Verbessern Sie die Leistung durch Indexierung und Abfrageoptimierung. 4. regelmäßig Sicherung und Überwachung von Datenbanken, um die Datensicherheit und die Leistungsoptimierung der Daten zu gewährleisten.

    MySQL: Schlüsselmerkmale und Funktionen erklärtMySQL: Schlüsselmerkmale und Funktionen erklärtApr 18, 2025 am 12:17 AM

    MySQL ist ein Open Source Relational Database Management -System, das in der Webentwicklung häufig verwendet wird. Zu den wichtigsten Funktionen gehören: 1. unterstützt mehrere Speichermotoren wie InnoDB und MyISAM, geeignet für verschiedene Szenarien; 2. Bietet Master-Slave-Replikationsfunktionen, um Lastausgleich und Datensicherung zu erleichtern. 3.. Verbessern Sie die Abfrageeffizienz durch Abfrageoptimierung und Index.

    Der Zweck von SQL: Interaktion mit MySQL -DatenbankenDer Zweck von SQL: Interaktion mit MySQL -DatenbankenApr 18, 2025 am 12:12 AM

    SQL wird verwendet, um mit der MySQL -Datenbank zu interagieren, um die Datenzusatz, Löschung, Änderung, Inspektion und Datenbankdesign zu realisieren. 1) SQL führt Datenoperationen über SELECT, INSERT, INTERATE, UPDATE, Löschen von Anweisungen durch. 2) Verwenden Sie Anweisungen für Datenbankdesign und -verwaltung create, ändern, fallen. 3) Komplexe Abfragen und Datenanalysen werden über SQL implementiert, um die Effizienz der Geschäftsentscheidungen zu verbessern.

    MySQL für Anfänger: Erste Schritte mit der DatenbankverwaltungMySQL für Anfänger: Erste Schritte mit der DatenbankverwaltungApr 18, 2025 am 12:10 AM

    Zu den grundlegenden Operationen von MySQL gehört das Erstellen von Datenbanken, Tabellen und die Verwendung von SQL zur Durchführung von CRUD -Operationen für Daten. 1. Erstellen Sie eine Datenbank: createdatabasemy_first_db; 2. Erstellen Sie eine Tabelle: CreateTableBooks (IDINGAUTO_INCRECTIONPRIMARYKEY, Titelvarchar (100) Notnull, AuthorVarchar (100) Notnull, veröffentlicht_yearint); 3.. Daten einfügen: InsertIntoBooks (Titel, Autor, veröffentlicht_year) va

    See all articles

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    Video Face Swap

    Video Face Swap

    Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

    Heiße Werkzeuge

    SublimeText3 Linux neue Version

    SublimeText3 Linux neue Version

    SublimeText3 Linux neueste Version

    Dreamweaver Mac

    Dreamweaver Mac

    Visuelle Webentwicklungstools

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    SecLists

    SecLists

    SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)