Dieser Artikel bringt Ihnen relevantes Wissen über MySQL, das hauptsächlich die relevanten Inhalte zur Einzeltabellenabfrage vorstellt. Ich hoffe, es wird für alle hilfreich sein.
Empfohlenes Lernen: MySQL-Video-Tutorial
Wenn wir Daten verarbeiten, sind Abfragevorgänge zweifellos von entscheidender Bedeutung. Wir können die in der Datenbank gespeicherten Daten effizient gestalten an den Benutzer.
Abfrage ist ein entscheidender Teil von Datenoperationen.
Wenn Sie beispielsweise unter allen Produkten alle Produkte mit einem Preis innerhalb eines bestimmten Bereichs finden möchten, möchten Sie die Daten in der Datenbank anzeigen Der Benutzer auf dem Client führt im Allgemeinen den Abfragevorgang aus. 查询是数据操作至关重要的一部分,
比如说在所有商品中查找出价格在规定范围内的所有商品,要想把数据库中的数据在客户端中展示给用户,一般都进行了查询的操作。
在实际开发中,我们要根据不同的需求,并且考虑查询的效率来决定怎样进行查询,学习查询前,可以先看看查询的完整语法:
SELECT 字段列表FROM 表名列表WHERE 条件列表GROUP BY 分组字段HAVING 分组后条件ORDER BY 排序字段LIMIT 分页限定
根据查询的完整语法中的关键字,我们分别来学习基础查询,条件查询,排序查询,分组查询和分页查询。
-- 删除stu表 drop table if exists stu; -- 创建stu表 CREATE TABLE stu ( id int, -- 编号 name varchar(10), -- 姓名 age int, -- 年龄 gender varchar(5), -- 性别 math double(5,2), -- 数学成绩 english double(5,2) -- 英语成绩 ); -- 添加数据 INSERT INTO stu(id,name,age,gender,math,english) VALUES (1,'小张',23,'男',66,78), (2,'小李',20,'女',98,87), (3,'小陈',55,'男',56,77), (4,'小樊',20,'女',76,65), (5,'小马',20,'男',86,NULL), (6,'小赵',57,'男',99,99);
, die bedingte Abfrage, die Sortierabfrage, die Gruppierungsabfrage und die Paging-Abfrage kennen.
Wir verwenden den folgenden Fall, um eine einzelne Tabellenabfrage zu lernen:
select 字段列表 from 表名;
select * from 表名;
select distinct 字段列表 from 表名;
select 字段名 别名 from 表名;
select name,math from stu;
Mehrere Abfragen Feldübungen:
select name,english 英语成绩 from stu;
Aliasoperationsübungen:
select 字段列表 from 表名 where 条件列表;
Operator | |
---|---|
> | |
zwischen… und… | |
in(…) | |
ist null / ist nicht null | |
Informationen zu Schülern abfragen, die älter als 20 Jahre sind: | select * from stu where age in(18,20,21); Nach dem Login kopieren |
Fuzzy-Abfrage verwendet das Schlüsselwort „like“ und Platzhalter können als Platzhalter verwendet werden: |
Fragen Sie Schülerinformationen ab, deren Name Zhang enthält :
select 字段列表 from 表名 order by 排序字段名1 [排序方式]...;
3. Sortierungsabfrage
3.1 Sortierungssyntaxselect 聚合函数 from 表名;
Wir verwenden die Groß-/Kleinschreibung im Vorwort, um eine Sortierabfrageübung durchzuführen:
Was ist eine Aggregatfunktion? Bei der Durchführung von Abfragevorgängen müssen wir häufig Vorgänge für eine gesamte Spalte ausführen. Wenn wir beispielsweise den Durchschnitt einer gesamten Spalte mit Leistungsdaten berechnen können, müssen wir eine Aggregatfunktion verwenden. Im Folgenden sind gängige Aggregatfunktionen aufgeführt:
Min(Spaltenname) | |
---|---|
Summe(Spaltenname) | Summe |
Durchschnitt(Spaltenname) | Durchschnitt |
一般语法: select 聚合函数 from 表名; Nach dem Login kopieren Nach dem Login kopieren
4.2 聚合函数练习我们使用前言中的案例进行聚合函数的练习: 统计该表中一共有几个学生: select count(id) from stu; Nach dem Login kopieren 上面我们使用某一字段进行运算,这样做可能面临的问题是某一个值可能是NULL,所以我们一般使用 select count(*) from stu; Nach dem Login kopieren 查询数学成绩的平均分: select avg(math) from stu; Nach dem Login kopieren 5. 分组查询5.1 分组查询语法select 字段列表 from 表名 [where 分组前的条件限定] group by 分组字段名 [having 分组后的条件过滤] Nach dem Login kopieren
5.2 分组查询练习我们使用前言中的案例进行分组查询练习: 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组: select gender, avg(math),count(*) from stu where math > 70 group by gender; Nach dem Login kopieren 查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组,分组之后人数大于2个的: select gender, avg(math),count(*) from stu where math > 70 group by gender having count(*) > 2; Nach dem Login kopieren 注: 6. 分页查询6.1 分页查询语法在大家的印象中,网页在展示大量的数据时,往往不是把数据一下全部展示出来,也是用分页展示的形式,其实就是对数据进行分页查询的操作,即每次只查询一页的数据展示到页面上。 select 字段列表 from 表名 limit 查询起始索引,查询条目数; Nach dem Login kopieren 在 5.2 分页查询练习我们使用前言中的案例进行分页查询练习: 从0开始查询,查询3条数据: select * from stu limit 0,3; Nach dem Login kopieren
推荐学习:mysql视频教程 |
Das obige ist der detaillierte Inhalt vonErweiterte Zusammenfassung der MySQL-Einzeltabellenabfrage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!