Rumah > pangkalan data > tutorial mysql > Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

青灯夜游
Lepaskan: 2021-12-20 17:25:07
ke hadapan
2930 orang telah melayarinya

Bagaimana untuk membuat pertanyaan dalam MySQL? Artikel berikut meringkaskan dan berkongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL, yang berbaloi untuk dikumpulkan.

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Untuk analisis data, MySQL kebanyakannya menggunakan pertanyaan, seperti pengisihan data, pengelompokan, penyahduplikasi, ringkasan, padanan rentetan, dsb. Jika data yang ditanya melibatkan berbilang jadual, anda perlu menyertai jadual ini. Artikel ini akan membincangkan tentang klausa pertanyaan yang biasa digunakan dalam MySQL, sejumlah 15. [Cadangan berkaitan: tutorial video mysql]

*1, *Isih: pesanan mengikut

Isih mengikut pesanan Dilaksanakan , sebagai contoh, untuk menanyakan data daripada jadual StuInfo dan mengisihnya mengikut umur. Penyataan sql ialah:

select * from stuinfo order by age;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Anda boleh melihat bahawa hasil pertanyaan disusun dalam susunan menaik mengikut umur jika anda ingin melaksanakan tertib menurun , cuma tambah desc pada penghujung, pernyataan sql ialah:

select * from stuinfo order by age desc;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Hasil pertanyaan pada ini masa adalah mengikut susunan umur yang menurun.

Di atas adalah untuk mengisih data berangka Jika ia adalah rentetan, anda juga boleh menggunakan susunan mengikut nama, penyataan SQL ialah:

select * from stuinfo order by stuname;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Seperti yang anda boleh lihat daripada di atas, pengisihan rentetan sebenarnya ialah mengisih mengikut huruf pertama dalam tertib menaik Sudah tentu, tarikh juga boleh diisih, sila fikirkan mengenainya sendiri.

*2, *Kumpulan: kumpulan mengikut

Kumpulan dilaksanakan melalui kumpulan mengikut klausa, contohnya, kepada kumpulan mengikut jantina, pernyataan sql ialah.

select gender,count(*) from stuinfo group by gender;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Kumpulan pernyataan sql di atas mengikut jantina dan memberikan bilangan orang dalam setiap kumpulan Pengelompokan mengikut medan lain juga serupa.

*3, *Deduplikasi: berbeza

Deduplikasi ialah operasi biasa dalam pemprosesan data, yang dilaksanakan melalui klausa yang berbeza, seperti pertanyaan Semua bandar tempat pelajar berada perlu dibuat pendua kerana sesetengah pelajar berada di bandar yang sama.

Pernyataan SQL ialah:

select distinct city from stuinfo;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Seperti yang anda lihat, penyahduplikasian adalah untuk menambah sebelum medan penyahduplikasi Hanya pergi ke yang berbeza.

*4, *Nilai nol: adalah batal/bukan batal

Nilai nol adalah untuk menilai sama ada medan kosong atau tidak kosong Contohnya, untuk menanyakan rekod dengan bandar kosong, pernyataan sql ialah:

select * from stuinfo where city is null;
Salin selepas log masuk

Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Anda boleh melihat bahawa pertanyaan itu kosong Rekod sebenarnya adalah keadaan di mana diikuti oleh adalah batal.

Sebaliknya, jika anda membuat pertanyaan untuk rekod di mana bandar tidak kosong, ikuti sahaja bukan nol Penyataan sql ialah:

select * from stuinfo where city is not null;
Salin selepas log masuk

Hasil pertanyaan:

<. 🎜 >Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*

5, *Ringkasan: pengiraan, nilai maksimum, jumlah, nilai min

Ringkasan sebenarnya adalah mengira dan mencari maksimum/ nilai nilai minimum, jumlah, purata, dsb.

Berapa banyak rekod dalam jadual statistik yang paling biasa digunakan, dilaksanakan melalui kiraan, pernyataan sql ialah:

select count(*) from stuinfo;
Salin selepas log masuk

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Soal nilai maksimum bagi medan dalam jadual Nilai/nilai minimum, direalisasikan melalui maks/min, sebagai contoh, untuk menanya umur maksimum, pernyataan sql ialah:

select max(age) from stuinfo;
Salin selepas log masuk
Hasil pertanyaan:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

Seterusnya Soalan: Bagaimana hendak menulis pernyataan SQL untuk menanyakan nama pelajar tertua?

Ini adalah pertanyaan bersyarat. Syaratnya ialah umur mesti sama dengan umur tertua, tulis pernyataan sql:

select stuname,age from stuinfo where age=(select max(age) from stuinfo);
Salin selepas log masuk
Hasil pertanyaan: <🎜. >

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)Seperti yang anda lihat daripada di atas, umur tertua sebenarnya ditanya sebagai syarat, dan kemudian nama dan umur yang sepadan disoal.

Tinggalkan soalan:

Bagaimana untuk menyemak nama pelajar bongsu? Untuk menjumlahkan, hanya gunakan jumlah Ia mestilah jumlah data berangka, serupa dengan kiraan. Ini tidak akan ditunjukkan.

Yang terakhir ialah min, gunakan purata, sebagai contoh, untuk menanyakan purata umur semua pelajar, pernyataan sql ialah:

Hasil pertanyaan:
select avg(age) from stuinfo;
Salin selepas log masuk

*6、 *别名:as

别名,就是as,意为用作,例如,查询出年龄的最大值、最小值和均值,sql语句为:

select max(age),min(age),avg(age) from stuinfo;
Salin selepas log masuk

查询结果:

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

这样显示字段名不太好看,我们可以用as起一个别名,sql语句为:

select max(age) as age_max,min(age) as age_min,avg(age) as age_avg from stuinfo;
Salin selepas log masuk

查询结果:

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*7、 *表的连接

当要查询的记录涉及两个或者两个以上的表时,就需要表的连接。

表的连接有三种:内连接、左连接和右连接。

(1)内连接:inner join

内连接相当于两个表的交集,如下图所示。

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

例如,有两个表:学员信息表和成绩表,有一个共同的列:学号。

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

现在想查询出每个学员的姓名和成绩,查询结果如下图所示。

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

以上查询结果中的姓名需要从第一个表中提取,成绩需要从第二个表中提取,这叫表的连接

因为学号是共同的列,所以根据学号连接,以上的这种连接方式是获取两个表中学号相同的记录,叫作内连接

具体的sql语句为:

select sname,score fromtb1 inner join tb2 on tb1.sid=tb2.sid;
Salin selepas log masuk

查询结果:

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

需要注意的是,连接条件用on。

(2)左连接:left join

左连接是以左表为基准,去匹配右表中的记录,如果右表中没有对应匹配记录则为空。

左连接用集合中的文氏图表示如下。

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

还是用以上提到的学员信息表和成绩表,左连接的示意图如下。

1Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

左连接的sql语句为:

select sname,score fromtb1 left join tb2 on tb1.sid=tb2.sid;
Salin selepas log masuk

查询结果:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

(3)右连接:right join

右连接是以右表为基准,去匹配左表中的记录,如果左表中没有对应匹配记录则为空。

右连接用集合中的文氏图表示如下。

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

还是用以上提到的学员信息表和成绩表,右连接的示意图如下。

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

右连接的sql语句为:

select sname,score fromtb1 right join tb2 on tb1.sid=tb2.sid;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*8、 *字符串匹配:like

有时候在字符串查找时,需要查找符合某个匹配模式的字符串。

例如,在表stuinfo中,查找城市中含有字符串‘an’的记录,sql语句为:

select * from stuinfo where city like &#39;%an%&#39;;
Salin selepas log masuk

注意:匹配模式中的%表示匹配任意长度的任意字符串。

*9、 *集合:in

查找属于某个集合的记录用in。

例如,查找城市为北京或者天津的记录,sql语句为:

select * from stuinfo where city in(&#39;Beijing&#39;,&#39;Tianjin&#39;);
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*10、 *条件语句:having

这里说的条件语句是having,跟where类似,但是一般和统计函数连用。

比如,查找平均年龄小于25岁的城市,sql语句为:

select city from stuinfo group by city having avg(age)<25;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

以上sql语句先按照城市分组,再跟条件语句having。

*11、 *区间查找:between and

between and用于查找符合某个区间(包含两个边界的值)的记录。

例如,查找年龄介于20到30岁之间的记录,sql语句为:

select * from stuinfo having age between 20 and 30;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*12、 *联结:union

联结,也叫联合,用于连接两个查询的结果,并且去重。

例如,两个表中都有学号,用sql语句分别从这两个表中查询出学号,然后联结。

select sid from tb1unionselect sid from tb2;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

以上sql语句相当于将两个select语句的查询结果用union合并,并且是去重合并。

如果不想去重,用union all即可,sql如下。

select sid from tb1union allselect sid from tb2;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

*13、 *日期格式化:date_format

在SQL中,对于日期时间的处理也是很常见的问题。

例如,按照年份、月份或者日期等对数据进行分组汇总,就需要从日期时间中提取年份、月份及日期等。

举个例子,获取每个学员的出生年份,sql语句为:

select date_format(birthdate,&#39;%Y&#39;) as birth_year from stuinfo;
Salin selepas log masuk

查询结果:

2Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

获取出生月份也是如此,只是参数用'%m',sql语句为:

select date_format(birthdate,&#39;%m&#39;) as birth_year from stuinfo;
Salin selepas log masuk

查询结果:

Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

获取到年份、月份后,就可以按照年份、月份进行分组查询统计了。

*14、 *条件分支:case语句

条件分支是数据统计中的一个很重要的应用,在MySQL中用case语句表达条件分支,case语句有以下两种用法。

用法一:

例如,根据学员所处的城市,将记录标记为一线城市及其他,sql语句为:

select distinct city,
  case city
    when &#39;Beijing&#39; then &#39;一线城市&#39;
    when &#39;Shanghai&#39; then &#39;一线城市&#39;
    else &#39;其他&#39; end as city_level
from stuinfo;
Salin selepas log masuk

查询结果:

3Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

从上面看到,case后面跟的是要判断的字段,when后跟的是不同的情况,then则是不同情况对应的类别,最后的else表示其他情况。

整个case语句相当于给原来的表增加一个字段:city_level,然后我们可以根据这个字段进行分组查询。

用法二:

例如,根据学员的年龄进行分层,青年、中年及其他,sql语句为:

select stuname,age,
  case when age<30 then &#39;青年&#39;
      when age>=30 and age<35 then &#39;中年&#39;
      else &#39;其他&#39; end as age_level
from stuinfo;
Salin selepas log masuk

查询结果:

3Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

从上面可以看到,case后面跟的是条件when,即年龄满足什么条件时,将其划分到对应的类别,最后的else表示其他情况。

整个case语句相当于给原来的表增加一个字段:age_level,然后我们可以根据这个字段进行分组查询。

*15、 *变量

最后,谈谈MySQL中的变量,当然,MySQL中的变量有好几种类型,这里只说用户变量,像@var这种。

例如,我们希望根据学员的年龄计算出每个人到35岁还有几年,这里可以定义一个变量并赋值为35,然后利用这个变量减去年龄就得到结果。

首先,定义变量var,sql语句为:

set @var:=35;
Salin selepas log masuk

接着,使用这个变量,sql语句为:

select @var-age as age_gap from stuinfo;
Salin selepas log masuk

查询结果:

3Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya)

当然,关于变量还有很多更复杂的用法,多用于计算连续登陆天数这种问题或者存储过程中。

更多编程相关知识,请访问:编程视频!!

Atas ialah kandungan terperinci Ringkaskan dan kongsi 15 klausa pertanyaan yang biasa digunakan dalam MySQL (datang dan kumpulkannya). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:juejin.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan