cari
Rumahpangkalan datatutorial mysqlBagaimana untuk menyelesaikan masalah pertanyaan sambungan dalam MySql

    Pertanyaan sambungan

    Apabila melakukan pertanyaan sambungan berbilang jadual, anda perlu menentukan jadual yang menjadi milik medan tersebut, yang boleh meningkatkan kecekapan pertanyaan. Jika anda tidak menyatakan jadual yang menjadi milik medan itu, Pangkalan data akan mencari medan

    • e daripada setiap jadual Nama medan: bermaksud mengambil medan daripada jadual emp

    • emp sebagai e: mekanisme alias jadual, anda boleh meninggalkan sebagai dan menulisnya terus sebagai emp

    • Pertanyaan sambungan: Ia juga boleh dipanggil pertanyaan jadual silang, yang perlu mengaitkan berbilang jadual untuk menanya data bersama

    • Jadual emp dan jadual jabatan digabungkan untuk menanyakan data jadual dan nama jabatan daripada jadual jabatan

    Nota: Apabila melakukan pertanyaan penyertaan, pastikan anda menulis syarat yang berkaitan untuk mengelakkan fenomena produk Cartesian

    Klasifikasi pertanyaan sertai

    Klasifikasi berdasarkan umur tatabahasa

    SQL92: Sintaks yang muncul pada tahun 1992

  • Kelebihan SQL99: Syarat sambungan dan syarat pertanyaan jadual dipisahkan Jika anda perlu menapis selanjutnya selepas sambungan, teruskan menambah tempat . Ia akan menjadi lebih jelas apabila menyambungkan berbilang jadual
  • Mengikut jadual Klasifikasi kaedah sambungan

    • Sambungan dalam: Cantuman setara, bukan setara sertai, sambung sendiri, dalam boleh diabaikan dan secara amnya tidak ditambah

    Jadual A sambung dalam Jadual B pada syarat persatuan

    Sambungan luar: sambung luar kiri (sambungan kiri), sambung luar kanan (sambungan kanan), sambung luar boleh diketepikan dan secara amnya tidak menambah

    • Sambungan luar kiri kiri Jadual B pada syarat persatuan

    Jadual B sebelah kanan luar sertai Jadual A pada keadaan persatuan

    • Cantum kiri Bandingkan jadual di sebelah kiri dengan jadual di sebelah kanan Sebarang kesamaan atau ketaksamaan dengan jadual kiri akan dipaparkan, manakala yang berada di jadual kanan yang memenuhi syarat akan dipaparkan, dan yang tidak memenuhi syarat tidak akan dipaparkan (cantuman kanan adalah sebaliknya)

    • Apa yang boleh dilakukan oleh cantuman kiri, cantuman kanan pasti boleh dilakukan

    • Dua jadual yang disambungkan adalah kedua-dua jadual utama dan boleh ditanya

      Fenomena produk Cartesian
    • Apabila dua jadual disambungkan untuk pertanyaan dan tiada syarat sambungan dinyatakan, bilangan hasil pertanyaan akhir ialah hasil daripada bilangan entri dalam dua jadual Fenomena ini dipanggil: Fenomena produk Cartesian (ditemui oleh Descartes, ini adalah fenomena matematik)

      Elakkan fenomena produk Cartesian: tambah syarat sambungan apabila menyambungkan berbilang jadual, dan tapis rekod yang memenuhi syarat ini

    Bilangan padanan tidak berkurangan semasa proses pemadanan, tetapi bilangan hasil pertanyaan akhir menjadi kurang kerana ia ditapis mengikut syarat sambungan

    Melalui produk Cartesian Fenomena menunjukkan bahawa lebih banyak kali jadual disambungkan, lebih rendah kecekapan Cuba elakkan bilangan sambungan jadual

    • cantuman dalam dan cantuman yang setara

      kerana syaratnya adalah. sama. , jadi ia dipanggil equijoin (data dengan syarat sambungan yang sama)
    • Soal nama jabatan di mana setiap pekerja berada, paparkan nama pekerja dan jabatan

    emp e dan dept d Jadual bersambung, dan syarat sambungan ialah: 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

    Kerana hanya ada satu sambungan jadual , kaedah pertanyaan khusus adalah dengan melihat satu jadual Buat dua jadual untuk menyambungkan diri anda, jadi ia menjadi sambung sendiri

    Tanya ketua atasan pekerja dan minta nama pekerja dan nama ketua yang sepadan untuk dipaparkan

    Satu jadual dianggap sebagai dua jadual Zhang, emp e mewakili jadual pekerja, emp m juga mewakili jadual ketua

    syarat sambungan: e.mgr = m.empno nombor ketua pekerja = nombor pekerja ketua

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

    Sambungan tidak setara

    Oleh kerana syarat sambungan bukan hubungan kesetaraan, ia dipanggil sambungan tidak setara

    Memaparkan maklumat pekerja dengan gaji melebihi 2000, dan memaparkan jabatan di mana mereka berada Nama

    --采用 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;

    Ketahui gred gaji setiap pekerja dan perlukan nama pekerja, gaji, gred gaji untuk dipaparkan

    select 
    	e.ename, e.sal, s.grade
    from
    	emp e
    (inner) join
    	salgrade s
    on
    	e.sal between s.losal and s.hisal;

    Sambungan luar

    Cantuman luar: Dalam cantuman luar, sambungan antara kedua-dua jadual mewujudkan perhubungan primer dan sekunder Pertanyaan utama ialah data bagi jadual utama, dan jadual kedua disoal mengikut perkaitan Iaitu, jika pihak lain tidak mempunyai rekod yang sepadan dengan jadual utama saya, maka pihak lain lalai adalah batal Kata kunci luar boleh diabaikan Cambung luar kanan: Cantuman luar kanan ialah cantuman luar kanan, yang bermaksud jadual di sebelah kanan kata kunci cantuman dianggap sebagai jadual utama, terutamanya untuk menggabungkan ini Semua data dalam jadual ditanya dan jadual di sebelah kiri disoal dengan perkaitan

    Caburan luar kiri: Yang dengan t kiri ialah cantuman luar kiri, yang bermaksud jadual di sebelah kiri kata kunci cantum akan menjadi Jadual dianggap sebagai jadual utama, terutamanya untuk menanyakan semua data dalam jadual ini, dan menanyakan jadual di sebelah kanan dengan perkaitan

    **Nota: Mana-mana gabungan hak mempunyai sambung kiri Cara menulis, sambung kiri ada cara untuk sambung kanan**

    查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来

    --左连接
    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;

    Bagaimana untuk menyelesaikan masalah pertanyaan sambungan dalam 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;

    Bagaimana untuk menyelesaikan masalah pertanyaan sambungan dalam 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 |
    	+--------+---------+------------+-------+-------+

    Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah pertanyaan sambungan dalam MySql. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan
    Artikel ini dikembalikan pada:亿速云. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
    MySQL: Blob dan penyimpanan No-SQL yang lain, apakah perbezaannya?MySQL: Blob dan penyimpanan No-SQL yang lain, apakah perbezaannya?May 13, 2025 am 12:14 AM

    Mysql'sblobissusuipableforstoringbinarydatawithinarelationaldatabase, sementara

    MySQL Tambah Pengguna: Sintaks, Pilihan, dan Amalan Terbaik KeselamatanMySQL Tambah Pengguna: Sintaks, Pilihan, dan Amalan Terbaik KeselamatanMay 13, 2025 am 12:12 AM

    Toaddauserinmysql, gunakan: createuser'username '@' host'identifiedby'password '; here'showtodoitsecurely: 1) choosethehostcareflelytocon trolaccess.2) SetResourcelImitSwithOptionsLikeMax_queries_per_hour.3) USESTRONG, UNIQUEPASSWORDS.4) Enforcessl/TLSConnectionswith

    MySQL: Bagaimana untuk mengelakkan jenis data rentetan kesilapan biasa?MySQL: Bagaimana untuk mengelakkan jenis data rentetan kesilapan biasa?May 13, 2025 am 12:09 AM

    Toavoidcommonmistakeswithstringdatatypesinmysql, fahamistringtypenuances, choosetherighttype, danManageencodingandcollationsettingsefectively.1) usecharfarfixed-lengthstrings, varcharforvariable-length, andtext/blobforlargerdata.2)

    MySQL: Jenis data rentetan dan enum?MySQL: Jenis data rentetan dan enum?May 13, 2025 am 12:05 AM

    Mysqloffersechar, varchar, teks, anddenumforstringdata.usecharforfixed-lengthstrings, varcharerforvariable-length, teks forlarger text, andenumforenforcingdataantegritywithaetofvalues.

    Blob Mysql: Cara mengoptimumkan permintaan gumpalanBlob Mysql: Cara mengoptimumkan permintaan gumpalanMay 13, 2025 am 12:03 AM

    Mengoptimumkan permintaan mysqlblob boleh dilakukan melalui strategi berikut: 1. Mengurangkan kekerapan pertanyaan gumpalan, gunakan permintaan bebas atau pemuatan kelewatan; 2. Pilih jenis gumpalan yang sesuai (seperti TinyBlob); 3. Pisahkan data gumpalan ke dalam jadual berasingan; 4. Mampat data gumpalan di lapisan aplikasi; 5. Indeks metadata gumpalan. Kaedah ini dapat meningkatkan prestasi dengan berkesan dengan menggabungkan pemantauan, caching dan data sharding dalam aplikasi sebenar.

    Menambah Pengguna ke MySQL: Tutorial LengkapMenambah Pengguna ke MySQL: Tutorial LengkapMay 12, 2025 am 12:14 AM

    Menguasai kaedah menambah pengguna MySQL adalah penting untuk pentadbir pangkalan data dan pemaju kerana ia memastikan keselamatan dan kawalan akses pangkalan data. 1) Buat pengguna baru menggunakan perintah CreateUser, 2) Berikan kebenaran melalui perintah geran, 3) Gunakan flushprivileges untuk memastikan kebenaran berkuatkuasa, 4) kerap mengaudit dan membersihkan akaun pengguna untuk mengekalkan prestasi dan keselamatan.

    Menguasai Jenis Data String MySQL: Varchar vs Text vs. CharMenguasai Jenis Data String MySQL: Varchar vs Text vs. CharMay 12, 2025 am 12:12 AM

    ChooseCHARforfixed-lengthdata,VARCHARforvariable-lengthdata,andTEXTforlargetextfields.1)CHARisefficientforconsistent-lengthdatalikecodes.2)VARCHARsuitsvariable-lengthdatalikenames,balancingflexibilityandperformance.3)TEXTisidealforlargetextslikeartic

    MySQL: Jenis Data String dan Pengindeksan: Amalan TerbaikMySQL: Jenis Data String dan Pengindeksan: Amalan TerbaikMay 12, 2025 am 12:11 AM

    Amalan terbaik untuk mengendalikan jenis data rentetan dan indeks dalam MySQL termasuk: 1) Memilih jenis rentetan yang sesuai, seperti char untuk panjang tetap, varchar untuk panjang berubah, dan teks untuk teks besar; 2) berhati-hati dalam pengindeksan, elakkan daripada mengindeks, dan buat indeks untuk pertanyaan umum; 3) Gunakan indeks awalan dan indeks teks penuh untuk mengoptimumkan carian rentetan panjang; 4) Secara kerap memantau dan mengoptimumkan indeks untuk memastikan indeks kecil dan cekap. Melalui kaedah ini, kita dapat mengimbangi membaca dan menulis prestasi dan meningkatkan kecekapan pangkalan data.

    See all articles

    Alat AI Hot

    Undresser.AI Undress

    Undresser.AI Undress

    Apl berkuasa AI untuk mencipta foto bogel yang realistik

    AI Clothes Remover

    AI Clothes Remover

    Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

    Undress AI Tool

    Undress AI Tool

    Gambar buka pakaian secara percuma

    Clothoff.io

    Clothoff.io

    Penyingkiran pakaian AI

    Video Face Swap

    Video Face Swap

    Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

    Artikel Panas

    Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
    3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
    Nordhold: Sistem Fusion, dijelaskan
    3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

    Alat panas

    SublimeText3 versi Mac

    SublimeText3 versi Mac

    Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

    VSCode Windows 64-bit Muat Turun

    VSCode Windows 64-bit Muat Turun

    Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

    Versi Mac WebStorm

    Versi Mac WebStorm

    Alat pembangunan JavaScript yang berguna

    PhpStorm versi Mac

    PhpStorm versi Mac

    Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

    EditPlus versi Cina retak

    EditPlus versi Cina retak

    Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod