


Bagaimana 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
Mengikut jadual Klasifikasi kaedah sambungan
- Sambungan dalam: Cantuman setara, bukan setara sertai, sambung sendiri, dalam boleh diabaikan dan secara amnya tidak ditambah
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
- 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
- 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
--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;
Salin selepas log masuk
Inner join self-joinKerana 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 --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;
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;
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;
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;
显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来
--外连接(右外连接) 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 | +--------+---------+------------+-------+-------+
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



MySQL adalah sistem pengurusan pangkalan data sumber terbuka. 1) Buat Pangkalan Data dan Jadual: Gunakan perintah Createdatabase dan Createtable. 2) Operasi Asas: Masukkan, Kemas kini, Padam dan Pilih. 3) Operasi lanjutan: Sertai, subquery dan pemprosesan transaksi. 4) Kemahiran Debugging: Semak sintaks, jenis data dan keizinan. 5) Cadangan Pengoptimuman: Gunakan indeks, elakkan pilih* dan gunakan transaksi.

Anda boleh membuka phpmyadmin melalui langkah -langkah berikut: 1. Log masuk ke panel kawalan laman web; 2. Cari dan klik ikon phpmyadmin; 3. Masukkan kelayakan MySQL; 4. Klik "Login".

MySQL adalah sistem pengurusan pangkalan data relasi sumber terbuka, terutamanya digunakan untuk menyimpan dan mengambil data dengan cepat dan boleh dipercayai. Prinsip kerjanya termasuk permintaan pelanggan, resolusi pertanyaan, pelaksanaan pertanyaan dan hasil pulangan. Contoh penggunaan termasuk membuat jadual, memasukkan dan menanyakan data, dan ciri -ciri canggih seperti Operasi Join. Kesalahan umum melibatkan sintaks SQL, jenis data, dan keizinan, dan cadangan pengoptimuman termasuk penggunaan indeks, pertanyaan yang dioptimumkan, dan pembahagian jadual.

MySQL dipilih untuk prestasi, kebolehpercayaan, kemudahan penggunaan, dan sokongan komuniti. 1.MYSQL Menyediakan fungsi penyimpanan dan pengambilan data yang cekap, menyokong pelbagai jenis data dan operasi pertanyaan lanjutan. 2. Mengamalkan seni bina pelanggan-pelayan dan enjin penyimpanan berganda untuk menyokong urus niaga dan pengoptimuman pertanyaan. 3. Mudah digunakan, menyokong pelbagai sistem operasi dan bahasa pengaturcaraan. 4. Mempunyai sokongan komuniti yang kuat dan menyediakan sumber dan penyelesaian yang kaya.

Redis menggunakan satu seni bina berulir untuk memberikan prestasi tinggi, kesederhanaan, dan konsistensi. Ia menggunakan I/O multiplexing, gelung acara, I/O yang tidak menyekat, dan memori bersama untuk meningkatkan keserasian, tetapi dengan batasan batasan konkurensi, satu titik kegagalan, dan tidak sesuai untuk beban kerja yang berintensifkan.

Kedudukan MySQL dalam pangkalan data dan pengaturcaraan sangat penting. Ia adalah sistem pengurusan pangkalan data sumber terbuka yang digunakan secara meluas dalam pelbagai senario aplikasi. 1) MySQL menyediakan fungsi penyimpanan data, organisasi dan pengambilan data yang cekap, sistem sokongan web, mudah alih dan perusahaan. 2) Ia menggunakan seni bina pelanggan-pelayan, menyokong pelbagai enjin penyimpanan dan pengoptimuman indeks. 3) Penggunaan asas termasuk membuat jadual dan memasukkan data, dan penggunaan lanjutan melibatkan pelbagai meja dan pertanyaan kompleks. 4) Soalan -soalan yang sering ditanya seperti kesilapan sintaks SQL dan isu -isu prestasi boleh disahpepijat melalui arahan jelas dan log pertanyaan perlahan. 5) Kaedah pengoptimuman prestasi termasuk penggunaan indeks rasional, pertanyaan yang dioptimumkan dan penggunaan cache. Amalan terbaik termasuk menggunakan urus niaga dan preparedStatemen

MySQL dan SQL adalah kemahiran penting untuk pemaju. 1.MYSQL adalah sistem pengurusan pangkalan data sumber terbuka, dan SQL adalah bahasa standard yang digunakan untuk mengurus dan mengendalikan pangkalan data. 2.MYSQL menyokong pelbagai enjin penyimpanan melalui penyimpanan data yang cekap dan fungsi pengambilan semula, dan SQL melengkapkan operasi data yang kompleks melalui pernyataan mudah. 3. Contoh penggunaan termasuk pertanyaan asas dan pertanyaan lanjutan, seperti penapisan dan penyortiran mengikut keadaan. 4. Kesilapan umum termasuk kesilapan sintaks dan isu -isu prestasi, yang boleh dioptimumkan dengan memeriksa penyataan SQL dan menggunakan perintah menjelaskan. 5. Teknik pengoptimuman prestasi termasuk menggunakan indeks, mengelakkan pengimbasan jadual penuh, mengoptimumkan operasi menyertai dan meningkatkan kebolehbacaan kod.

Membina pangkalan data SQL melibatkan 10 langkah: memilih DBMS; memasang DBMS; mewujudkan pangkalan data; mewujudkan jadual; memasukkan data; mengambil data; mengemas kini data; memadam data; menguruskan pengguna; Menyandarkan pangkalan data.
