Rumah pangkalan data SQL 常见的sql查询语句有哪些

常见的sql查询语句有哪些

Oct 26, 2020 am 10:06 AM
pernyataan pertanyaan sql

常见的sql查询语句有:1、查看表结构【SQL>DESC emp;】;2、查询所有列【SQL>SELECT * FROM emp】;3、查询指定列【SQL>SELECT empmo,】;4、查询指定行【SQL>SELECT * FROM】。

常见的sql查询语句有哪些

常见的sql查询语句有:

一、简单查询语句

1. 查看表结构

SQL>DESC emp;
Salin selepas log masuk

2. 查询所有列

SQL>SELECT * FROM emp;
Salin selepas log masuk

3. 查询指定列

SQL>SELECT empmo, ename, mgr FROM emp;
Salin selepas log masuk

SQL>SELECT DISTINCT mgr FROM emp; 只显示结果不同的项

4. 查询指定行

SQL>SELECT * FROM emp WHERE job='CLERK';
Salin selepas log masuk

5. 使用算术表达式

SQL>SELECT ename, sal*13+nvl(comm,0)  FROM emp;
Salin selepas log masuk

nvl(comm,1)的意思是,如果comm中有值,则nvl(comm,1)=comm; comm中无值,则nvl(comm,1)=0。

SQL>SELECT ename, sal*13+nvl(comm,0) year_sal FROM emp; (year_sal为别名,可按别名排序)

SQL>SELECT * FROM emp WHERE hiredate>'01-1月-82';
Salin selepas log masuk

6. 使用like操作符(%,_)

%表示一个或多个字符,_表示一个字符,[charlist]表示字符列中的任何单一字符,[^charlist]或者[!charlist]不在字符列中的任何单一字符。

SQL>SELECT * FROM emp WHERE ename like 'S__T%';
Salin selepas log masuk

7. 在where条件中使用In

SQL>SELECT * FROM emp WHERE job IN ('CLERK','ANALYST');
Salin selepas log masuk

8. 查询字段内容为空/非空的语句

SQL>SELECT * FROM emp WHERE mgr IS/IS NOT NULL;
Salin selepas log masuk

9. 使用逻辑操作符号

SQL>SELECT * FROM emp WHERE (sal>500 or job='MANAGE') and ename like 'J%';
Salin selepas log masuk

10. 将查询结果按字段的值进行排序

SQL>SELECT * FROM emp ORDER BY deptno, sal DESC;
Salin selepas log masuk

(按部门升序,并按薪酬降序)

11. 使用case ... when ... then ... end处理查询结果

SQL>SELECT CASE a WHEN "original_a" THEN "新命名Aa" WHEN "original_b" THEN "新命名Bb" END AS XXX;

选择表中的a字段并命名为XXX,当a的内容为original_a时,内容展示为“新命名Aa”。

12. 格式化日期数据

SQL>SELECT DATE_FORMAT(start_time,"%Y-%m-%d") as "时间";
Salin selepas log masuk

二、复杂查询

1. 数据分组(max,min,avg,sum,count)

SQL>SELECT MAX(sal),MIN(age),AVG(sal),SUM(sal) from emp;
SQL>SELECT * FROM emp where sal=(SELECT MAX(sal) from emp));
SQL>SELEC COUNT(*) FROM emp;
Salin selepas log masuk

2. group by(用于对查询结果的分组统计) 和 having子句(用于限制分组显示结果)

SQL>SELECT deptno,MAX(sal),AVG(sal) FROM emp GROUP BY deptno;
SQL>SELECT deptno, job, AVG(sal),MIN(sal) FROM emp group by deptno,job having AVG(sal)<2000;
Salin selepas log masuk

对于数据分组的总结:

a. 分组函数只能出现在选择列表、having、order by子句中(不能出现在where中)

b. 如果select语句中同时包含有group by, having, order by,那么它们的顺序是group by, having, order by。

c. 在选择列中如果有列、表达式和分组函数,那么这些列和表达式必须出现在group by子句中,否则就是会出错。也即:SELECT子句中的列名必须为分组列或列函数

使用group by不是使用having的前提条件。

3. 多表查询

SQL>SELECT e.name,e.sal,d.dname FROM emp e, dept d WHERE e.deptno=d.deptno order by d.deptno;
SQL>SELECT e.ename,e.sal,s.grade FROM emp e,salgrade s WHER e.sal BETWEEN s.losal AND s.hisal;
Select a.*, b.x, c.y from a
  left outer join (Select * from tablex where condition1)b
  on a.id=b.id
  left outer join (Select * from tabley where condition2)c
  on a.id=c.id
where condition3;
Salin selepas log masuk

以选出的数据为新表进行左连接查询;来自:https://q.cnblogs.com/q/67530/

4. 自连接(指同一张表的连接查询)

SQL>SELECT er.ename, ee.ename mgr_name from emp er, emp ee where er.mgr=ee.empno;
Salin selepas log masuk

5. 子查询(嵌入到其他sql语句中的select语句,也叫嵌套查询)

5.1 单行子查询

SQL>SELECT ename FROM emp WHERE deptno=(SELECT deptno FROM emp where ename=&#39;SMITH&#39;);
Salin selepas log masuk

查询表中与smith同部门的人员名字。因为返回结果只有一行,所以用“=”连接子查询语句

5.2 多行子查询

SQL>SELECT ename,job,sal,deptno from emp WHERE job IN (SELECT DISTINCT job FROM emp WHERE deptno=10);
Salin selepas log masuk

查询表中与部门号为10的工作相同的员工的姓名、工作、薪水、部门号。因为返回结果有多行,所以用“IN”连接子查询语句。

in与exists的区别: exists() 后面的子查询被称做相关子查询,它是不返回列表的值的。只是返回一个ture或false的结果,其运行方式是先运行主查询一次,再去子查询里查询与其对 应的结果。如果是ture则输出,反之则不输出。再根据主查询中的每一行去子查询里去查询。in()后面的子查询,是返回结果集的,换句话说执行次序和 exists()不一样。子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表去。符合要求的输出,反之则不输出。

5.3 使用ALL

SQL>SELECT ename,sal,deptno FROM emp WHERE sal> ALL (SELECT sal FROM emp WHERE deptno=30);或SQL>SELECT ename,sal,deptno FROM emp WHERE sal> (SELECT MAX(sal) FROM emp WHERE deptno=30);
Salin selepas log masuk

查询工资比部门号为30号的所有员工工资都高的员工的姓名、薪水和部门号。以上两个语句在功能上是一样的,但执行效率上,函数会高 得多。

5.4 使用ANY

SQL>SELECT ename,sal,deptno FROM emp WHERE sal> ANY (SELECT sal FROM emp WHERE deptno=30);或SQL>SELECT ename,sal,deptno FROM emp WHERE sal> (SELECT MIN(sal) FROM emp WHERE deptno=30);
Salin selepas log masuk

查询工资比部门号为30号的任意一个员工工资高(只要比某一员工工资高即可)的员工的姓名、薪水和部门号。以上两个语句在功能上是 一样的,但执行效率上,函数会高得多。

5.5 多列子查询

SQL>SELECT * FROM emp WHERE (job, deptno)=(SELECT job, deptno FROM emp WHERE ename=&#39;SMITH&#39;);
Salin selepas log masuk

5.6 在from子句中使用子查询

 SQL>SELECT emp.deptno,emp.ename,emp.sal,t_avgsal.avgsal FROM emp,(SELECT emp.deptno,avg(emp.sal) avgsal FROM emp GROUP BY emp.deptno) t_avgsal where emp.deptno=t_avgsal.deptno AND emp.sal>t_avgsal.avgsal ORDER BY emp.deptno;
Salin selepas log masuk

5.7 分页查询

数据库的每行数据都有一个对应的行号,称为rownum.

SQL>SELECT a2.* FROM (SELECT a1.*, ROWNUM rn FROM (SELECT * FROM emp ORDER BY sal) a1 WHERE ROWNUM<=10) a2 WHERE rn>=6;
Salin selepas log masuk

指定查询列、查询结果排序等,都只需要修改最里层的子查询即可。

5.8 用查询结果创建新表

SQL>CREATE TABLE mytable (id,name,sal,job,deptno) AS SELECT empno,ename,sal,job,deptno FROM emp;
Salin selepas log masuk

5.9 合并查询(union 并集, intersect 交集, union all 并集+交集, minus差集)

SQL>SELECT ename, sal, job FROM emp WHERE sal>2500 UNION(INTERSECT/UNION ALL/MINUS) SELECT ename, sal, job FROM emp WHERE job=&#39;MANAGER&#39;;
Salin selepas log masuk

合并查询的执行效率远高于and,or等逻辑查询。

5.10 使用子查询插入数据

SQL>CREATE TABLE myEmp(empID number(4), name varchar2(20), sal number(6), job varchar2(10), dept number(2));
Salin selepas log masuk

先建一张空表;

SQL>INSERT INTO myEmp(empID, name, sal, job, dept) SELECT empno, ename, sal, job, deptno FROM emp WHERE deptno=10;
Salin selepas log masuk

再将emp表中部门号为10的数据插入到新表myEmp中,实现数据的批量查询。

5.11 使用了查询更新表中的数据

SQL>UPDATE emp SET(job, sal, comm)=(SELECT job, sal, comm FROM emp where ename=&#39;SMITH&#39;) WHERE ename=&#39;SCOTT&#39;;
Salin selepas log masuk

相关免费学习推荐:SQL视频教程

Atas ialah kandungan terperinci 常见的sql查询语句有哪些. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimanakah saya mematuhi Peraturan Privasi Data (GDPR, CCPA) menggunakan SQL? Bagaimanakah saya mematuhi Peraturan Privasi Data (GDPR, CCPA) menggunakan SQL? Mar 18, 2025 am 11:22 AM

Artikel membincangkan menggunakan SQL untuk pematuhan GDPR dan CCPA, yang memberi tumpuan kepada pengabaian data, permintaan akses, dan penghapusan automatik data yang sudah lapuk. (159 aksara)

Bagaimanakah saya melaksanakan pembahagian data dalam SQL untuk prestasi dan skalabiliti? Bagaimanakah saya melaksanakan pembahagian data dalam SQL untuk prestasi dan skalabiliti? Mar 18, 2025 am 11:14 AM

Artikel membincangkan pelaksanaan pembahagian data dalam SQL untuk prestasi dan skalabiliti yang lebih baik, kaedah perincian, amalan terbaik, dan alat pemantauan.

Bagaimanakah saya mengamankan pangkalan data SQL saya terhadap kelemahan biasa seperti suntikan SQL? Bagaimanakah saya mengamankan pangkalan data SQL saya terhadap kelemahan biasa seperti suntikan SQL? Mar 18, 2025 am 11:18 AM

Artikel ini membincangkan mendapatkan pangkalan data SQL terhadap kelemahan seperti suntikan SQL, menekankan pernyataan yang disediakan, pengesahan input, dan kemas kini tetap.

Cara menggunakan datetime sql Cara menggunakan datetime sql Apr 09, 2025 pm 06:09 PM

Jenis data DateTime digunakan untuk menyimpan maklumat tarikh dan masa ketepatan tinggi, dari 0001-01-01 00:00:00 hingga 9999-12-31 23: 59: 59.99999999, dan sintetik adalah. Fungsi penukaran zon, tetapi perlu menyedari isu -isu yang berpotensi apabila menukarkan ketepatan, pelbagai dan zon masa.

Cara Menggunakan SQL Jika Penyataan Cara Menggunakan SQL Jika Penyataan Apr 09, 2025 pm 06:12 PM

SQL Jika pernyataan digunakan untuk melaksanakan pernyataan SQL secara kondusif, dengan sintaks sebagai: jika (keadaan) maka {pernyataan} else {statement} end if;. Keadaan ini boleh menjadi ungkapan SQL yang sah, dan jika keadaan itu benar, laksanakan klausa kemudian; Sekiranya keadaan itu palsu, laksanakan klausa lain. Jika pernyataan boleh bersarang, membolehkan pemeriksaan bersyarat yang lebih kompleks.

Cara membuat jadual dengan SQL Server menggunakan pernyataan SQL Cara membuat jadual dengan SQL Server menggunakan pernyataan SQL Apr 09, 2025 pm 03:48 PM

Cara membuat jadual menggunakan penyataan SQL di SQL Server: Buka SQL Server Management Studio dan sambungkan ke pelayan pangkalan data. Pilih pangkalan data untuk membuat jadual. Masukkan pernyataan Buat Jadual untuk menentukan nama jadual, nama lajur, jenis data, dan kekangan. Klik butang Jalankan untuk membuat jadual.

Cara memadam baris yang memenuhi kriteria tertentu dalam SQL Cara memadam baris yang memenuhi kriteria tertentu dalam SQL Apr 09, 2025 pm 12:24 PM

Gunakan pernyataan padam untuk memadam data dari pangkalan data dan tentukan kriteria penghapusan melalui klausa WHERE. Contoh Sintaks: Padam dari table_name di mana keadaan; Nota: Sandarkan data sebelum melaksanakan operasi memadam, sahkan pernyataan dalam persekitaran ujian, gunakan klausa had untuk mengehadkan bilangan baris yang dipadam, periksa dengan teliti klausa di mana untuk mengelakkan misdeletion, dan gunakan indeks untuk mengoptimumkan kecekapan penghapusan jadual besar.

Penggunaan pengisytiharan dalam SQL Penggunaan pengisytiharan dalam SQL Apr 09, 2025 pm 04:45 PM

Kenyataan pengisytiharan dalam SQL digunakan untuk mengisytiharkan pembolehubah, iaitu, ruang letak yang menyimpan nilai pembolehubah. Sintaks adalah: mengisytiharkan & lt; nama pembolehubah & gt; & lt; jenis data & gt; [Lalai & lt; nilai lalai & gt;]; di mana & lt; nama pembolehubah & gt; adalah nama pembolehubah, & lt; jenis data & gt; adalah jenis datanya (seperti varchar atau integer), dan [lalai & lt; nilai lalai & gt;] adalah nilai permulaan pilihan. Mengisytiharkan pernyataan boleh digunakan untuk menyimpan perantaraan

See all articles