MySQL学习——查询表里的数据

MySQL学习——查询表里的数据

摘要:本文主要学习了使用DQL语句查询表里数据的方法。

数据查询

语法

1 select [distinct] 列1 [as ‘别名1‘], ..., 列n [as ‘别名n‘] from 表名
2 [where 表达式]
3 [group by 表达式]
4 [having 表达式]
5 [order by 表达式]
6 [limit 起始编号, 查询条数]

说明

1 列1, ..., 列n:表示查询的字段,查询多个字段用“,”分隔,使用“*”号表示查询全部字段,使用“distinct”关键字去重,使用“as”设置别名。
2 表名:表示查询数据的来源,可以是单个或多个,多个表名用,分隔。
3 where 表达式:可选,限定查询满足的条件。
4 group by 表达式:可选,按照指定的字段分组。
5 having 表达式:可选,限定查询满足的条件,用于使用了聚合函数限定条件。
6 order by 表达式:可选,指明排序的方式,升序(asc)和降序(desc)。
7 limit 起始编号, 查询条数:可选,设置每次显示查询出来的数据条数。

查询全部和指定列

查询所有成绩,通配符“*”查询所有字段:

 1 mysql> select * from score;
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  1 | 张三    | 计算机    |    98 |
 6 |  2 | 张三    | 英语      |    53 |
 7 |  3 | 李四    | 计算机    |    48 |
 8 |  4 | 李四    | 中文      |    38 |
 9 |  5 | 王五    | 中文      |    95 |
10 |  6 | 赵六    | 计算机    |    70 |
11 |  7 | 赵六    | 英语      |    92 |
12 |  8 | 赵六    | 中文      |    73 |
13 |  9 | 孙七    | 英语      |    94 |
14 | 10 | 周八    | 计算机    |    90 |
15 | 11 | 周八    | 英语      |    85 |
16 | 12 | 吴九    | 计算机    |    90 |
17 | 13 | 吴九    | 中文      |    55 |
18 +----+---------+-----------+-------+
19 13 rows in set (0.00 sec)
20
21 mysql> 

查询姓名、课程、成绩:

 1 mysql> select student, course, grade from score;
 2 +---------+-----------+-------+
 3 | student | course    | grade |
 4 +---------+-----------+-------+
 5 | 张三    | 英语      |    53 |
 6 | 李四    | 计算机    |    48 |
 7 | 李四    | 中文      |    38 |
 8 | 王五    | 中文      |    95 |
 9 | 赵六    | 计算机    |    70 |
10 | 赵六    | 英语      |    92 |
11 | 赵六    | 中文      |    73 |
12 | 孙七    | 英语      |    94 |
13 | 周八    | 计算机    |    90 |
14 | 周八    | 英语      |    85 |
15 | 吴九    | 计算机    |    90 |
16 | 吴九    | 中文      |    55 |
17 +---------+-----------+-------+
18 12 rows in set (0.00 sec)
19
20 mysql> 

去重查询

查询所有课程名称:

 1 mysql> select distinct course from score;
 2 +-----------+
 3 | course    |
 4 +-----------+
 5 | 英语      |
 6 | 计算机    |
 7 | 中文      |
 8 +-----------+
 9 3 rows in set (0.00 sec)
10
11 mysql> 

使用别名查询

查询姓名、课程、成绩并显示表头为中文,使用别名时,as可省略:

 1 mysql> select student ‘姓名‘, course ‘课程‘, grade ‘成绩‘ from score;
 2 +--------+-----------+--------+
 3 | 姓名   | 课程      | 成绩   |
 4 +--------+-----------+--------+
 5 | 张三   | 英语      |     53 |
 6 | 李四   | 计算机    |     48 |
 7 | 李四   | 中文      |     38 |
 8 | 王五   | 中文      |     95 |
 9 | 赵六   | 计算机    |     70 |
10 | 赵六   | 英语      |     92 |
11 | 赵六   | 中文      |     73 |
12 | 孙七   | 英语      |     94 |
13 | 周八   | 计算机    |     90 |
14 | 周八   | 英语      |     85 |
15 | 吴九   | 计算机    |     90 |
16 | 吴九   | 中文      |     55 |
17 +--------+-----------+--------+
18 12 rows in set (0.00 sec)
19
20 mysql> 

限制查询条数

查询五条成绩数据:

 1 mysql> select * from score limit 5;
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  2 | 张三    | 英语      |    53 |
 6 |  3 | 李四    | 计算机    |    48 |
 7 |  4 | 李四    | 中文      |    38 |
 8 |  5 | 王五    | 中文      |    95 |
 9 |  6 | 赵六    | 计算机    |    70 |
10 +----+---------+-----------+-------+
11 5 rows in set (0.00 sec)
12
13 mysql> 

对查询结果进行排序

查询中文课程的成绩并从高到低排序:

 1 mysql> select * from score where course = ‘中文‘ order by grade desc;
 2 +----+---------+--------+-------+
 3 | id | student | course | grade |
 4 +----+---------+--------+-------+
 5 |  5 | 王五    | 中文   |    95 |
 6 |  8 | 赵六    | 中文   |    73 |
 7 | 13 | 吴九    | 中文   |    55 |
 8 |  4 | 李四    | 中文   |    38 |
 9 +----+---------+--------+-------+
10 4 rows in set (0.00 sec)
11
12 mysql> 

对查询结果进行分组

将成绩按课程分组并查询每个课程的平均分:

 1 mysql> select course, avg(grade) from score group by course;
 2 +-----------+------------+
 3 | course    | avg(grade) |
 4 +-----------+------------+
 5 | 计算机    |    74.5000 |
 6 | 英语      |    81.0000 |
 7 | 中文      |    65.2500 |
 8 +-----------+------------+
 9 3 rows in set (0.00 sec)
10
11 mysql> 

将成绩按课程分组并查询每个课程的平均分,只显示平均分大于70的结果:

 1 mysql> select course, avg(grade) from score group by course having avg(grade) > 70;
 2 +-----------+------------+
 3 | course    | avg(grade) |
 4 +-----------+------------+
 5 | 计算机    |    74.5000 |
 6 | 英语      |    81.0000 |
 7 +-----------+------------+
 8 2 rows in set (0.01 sec)
 9
10 mysql> 

使用条件查询

查询计算机的成绩:

 1 mysql> select * from score where course = ‘计算机‘;
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  1 | 张三    | 计算机    |    98 |
 6 |  3 | 李四    | 计算机    |    48 |
 7 |  6 | 赵六    | 计算机    |    70 |
 8 | 10 | 周八    | 计算机    |    90 |
 9 | 12 | 吴九    | 计算机    |    90 |
10 +----+---------+-----------+-------+
11 5 rows in set (0.00 sec)
12
13 mysql> 

内连接查询

内连接查询返回的是同时满足两个结果集的记录。

使用inner join查询所有学生的计算机课程的成绩,inner可省略:

 1 mysql> select stu.*, sco.course, sco.grade
 2     -> from student stu
 3     -> join score sco on stu.name = sco.student and sco.course = ‘计算机‘;
 4 +-----+--------+------+-------+------------+--------------------+-----------+-------+
 5 | id  | name   | sex  | birth | department | address            | course    | grade |
 6 +-----+--------+------+-------+------------+--------------------+-----------+-------+
 7 | 904 | 李四   | 男   |  1990 | 英语系     | 辽宁省阜新市       | 计算机    |    48 |
 8 | 908 | 周八   | 男   |  1986 | 中文系     | 北京市昌平区       | 计算机    |    90 |
 9 | 909 | 吴九   | 女   |  1996 | 中文系     | 湖北省武汉市       | 计算机    |    90 |
10 +-----+--------+------+-------+------------+--------------------+-----------+-------+
11 3 rows in set (0.00 sec)
12
13 mysql> 

结果仅显示有计算机成绩的记录,没有成绩的不显示。

外连接查询

外连接分为左外连接和右外连接,分别以左表和右表作为主表匹配,保留主表中存在但另一张表中不存在的的数据。

使用left join查询所有学生的计算机课程的成绩:

 1 mysql> select stu.*, sco.course, sco.grade
 2     -> from student stu
 3     -> left join score sco on stu.name = sco.student and sco.course = ‘计算机‘;
 4 +-----+--------+------+-------+--------------+--------------------+-----------+-------+
 5 | id  | name   | sex  | birth | department   | address            | course    | grade |
 6 +-----+--------+------+-------+--------------+--------------------+-----------+-------+
 7 | 904 | 李四   | 男   |  1990 | 英语系       | 辽宁省阜新市       | 计算机    |    48 |
 8 | 908 | 周八   | 男   |  1986 | 中文系       | 北京市昌平区       | 计算机    |    90 |
 9 | 909 | 吴九   | 女   |  1996 | 中文系       | 湖北省武汉市       | 计算机    |    90 |
10 | 903 | 张三   | 女   |  1990 | 中文系       | 湖南省永州市       | NULL      |  NULL |
11 | 905 | 王五   | 女   |  1991 | 英语系       | 福建省厦门市       | NULL      |  NULL |
12 | 906 | 王六   | 男   |  1988 | 计算机系     | 湖南省衡阳市       | NULL      |  NULL |
13 | 907 | 孙七   | 男   |  1985 | 计算机系     | 北京市海淀区       | NULL      |  NULL |
14 +-----+--------+------+-------+--------------+--------------------+-----------+-------+
15 7 rows in set (0.00 sec)
16
17 mysql> 

结果也显示了没有计算机成绩的记录,没有匹配到的数据使用Null表示。

子查询

子查询指一个查询语句嵌套在另一个查询语句内部的查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或者多个表。

子查询中常用的关键字有in和exists,也可以使用比较运算符。

in子查询

in子查询主要用于判断指定字段的值是否存在于子查询的结果集中。

如果子查询的记录较少,主查询的记录较多时使用in,因为这时用到了主表上的索引。

查询所有英语系的学生成绩:

 1 mysql> select * from score where student in (select name from student where department = ‘英语系‘);
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  3 | 李四    | 计算机    |    48 |
 6 |  4 | 李四    | 中文      |    38 |
 7 |  5 | 王五    | 中文      |    95 |
 8 +----+---------+-----------+-------+
 9 3 rows in set (0.00 sec)
10
11 mysql> 

exists子查询

exists子查询主要用于判断子查询的结果集是否为空。

如果子查询的记录较多,主查询的记录较少时使用exists,因为这时用到了子表上的索引。

查询是否存在数学系的学生成绩:

1 mysql> select * from score where exists (select id from student where department = ‘数学系‘);
2 Empty set (0.00 sec)
3
4 mysql> 

查询是否存在英语系的学生成绩:

 1 mysql> select * from score sco where exists (select stu.id from student stu where stu.department = ‘英语系‘);
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  2 | 张三    | 英语      |    53 |
 6 |  3 | 李四    | 计算机    |    48 |
 7 |  4 | 李四    | 中文      |    38 |
 8 |  5 | 王五    | 中文      |    95 |
 9 |  6 | 赵六    | 计算机    |    70 |
10 |  7 | 赵六    | 英语      |    92 |
11 |  8 | 赵六    | 中文      |    73 |
12 |  9 | 孙七    | 英语      |    94 |
13 | 10 | 周八    | 计算机    |    90 |
14 | 11 | 周八    | 英语      |    85 |
15 | 12 | 吴九    | 计算机    |    90 |
16 | 13 | 吴九    | 中文      |    55 |
17 +----+---------+-----------+-------+
18 12 rows in set (0.00 sec)
19
20 mysql> 

查询所有英语系的学生成绩:

 1 mysql> select * from score sco where exists (select stu.id from student stu where sco.student = stu.name and stu.department = ‘英语系‘);
 2 +----+---------+-----------+-------+
 3 | id | student | course    | grade |
 4 +----+---------+-----------+-------+
 5 |  3 | 李四    | 计算机    |    48 |
 6 |  4 | 李四    | 中文      |    38 |
 7 |  5 | 王五    | 中文      |    95 |
 8 +----+---------+-----------+-------+
 9 3 rows in set (0.00 sec)
10
11 mysql> 

比较运算符子查询

使用大于、小于、等于、不等于等其他比较运算符判断子查询是否满足。

1 mysql> select * from score sco where sco.student = (select stu.name from student stu where stu.id = 903);
2 +----+---------+--------+-------+
3 | id | student | course | grade |
4 +----+---------+--------+-------+
5 |  2 | 张三    | 英语   |    53 |
6 +----+---------+--------+-------+
7 1 row in set (0.00 sec)
8
9 mysql> 

原文地址:https://www.cnblogs.com/shamao/p/11594170.html

时间: 2024-08-13 02:07:06

MySQL学习——查询表里的数据的相关文章

MySQL学习——操作表里的数据

MySQL学习——操作表里的数据 摘要:本文主要学习了使用DML语句操作表里数据的方法. 插入数据 语法 通过传入数据插入: 1 insert into 表名 [(列名1, …, 列名n)] values (值1, …, 值n); 通过查询数据插入: 1 insert into 表名 [(列1, ..., 列n)] 2 select 列1, ..., 列n from 查询的表; 实例 1 mysql> insert into score values (null, '张三', '计算机', 98

MySQL学习笔记之五 有关数据表操作

MySQL在创建表的时候,创建一个.frm文件保存表和列定义.索引存储在一个有.MYI(MYindex)扩展名的文件并且数据存储在有.MYD(MYData)扩展名的文件中.   一.用SHOW/ DESCRIBE语句显示数据表的信息 语法: SHOW TABLES [FROM db_name] [LIKE wild] or SHOW COLUMNS FROM tbl_name [FROM db_name] [LIKE wild] or SHOW INDEX FROM tbl_name [FROM

mysql模糊查询表里的json格式的数据-177

mysql里查询 json 数据 1.mysql里有个字段存储的是json格式的数据, 2.现在需要从页面传递参数到php再进行搜索匹配关键字, 3.将关键字页json_encode后,去like匹配这个字段,匹配不到 解决方案: 1.只针对中文搜索,存的数据一样是json,josn里面的中文一般是unicode编码的,将关键字编码一下. 2.在mysql里,"\" 是需要转义的.两种解决办法: a)因此使用"\\"来查询,数据依然是空.(mysql斜杆转义之后,会

MySQL学习总结(五) --- 表数据查询

查询数据记录,是指从数据库对象表中获取所要查询的数据记录,该操作可以说是数据最基本的操作之一,也是使用频率最高.最重要的数据操作. 1.单表数据记录查询 1.1.简单数据查询 SELECT field1,field2,…,fieldn FROM table_name,filed可以是表中所有的字段,也可以是部分字段. SELECT * FROM table_name ,从表中查询所有的数据.*符号可以代替所有的字段,但是这种方式不够灵活,只能按照表中字段的顺序固定进行显示,不能够随便改变字段的显

MySQL时间段查询,无数据补0

上一节提到分时间段统计,可是无数据的时候不显示,而此时我们需要让他显示0. 首先我们需要建一个时间表. CREATE TABLE `my_date` ( `date` date NOT NULL, PRIMARY KEY (`date`) ) 并且插入一些数据,具体怎么插入有好多种方法,目的是生成我们需要的时间格式,如下 以下就要用到我们的时间表,与我们的数据表进行连接查询了.呃,中间的1你们可以忽略啊!!你们需要看的只有 t 和 count mysql> select DATE_FORMAT(

MySQL学习笔记十一:数据导入与导出

数据导入 1.mysqlimport命令行导入数据 在使用mysqlimport命令导入数据时,数据来源文件名要和目标表一致,不想改文件名的话,可以复制一份创建临时文件,示例如下. 建立一个文本users.txt,内容如下: 1001,张三,zhangsan@163.com 1002,李四,zhangsan@126.com 1003,王五,zhangsan@qq.com 1004,李白,zhangsan@hotmail.com 创建一个表users mysql> create table if

mysql将查询到的数据导出为excel

现在需要将mysql库中的一些数据导出为excel,然后打印.其实实现上面说的需求很简单,只要你把sql语句写出来,然后导出为excel即可 具体实现流程如下: 1.写出sql语句,查询出结果. 2.在查询的结果上点击右键,选择"导出所有表数据记录/结果为..." 如图所示: 选择"导出所有表数据记录/结果为..."之后出现如下图所示 点击导出即可. ======================================================== 需

mysql学习笔记之六(数据定义语言DDL)

SQL语言包括四类种主要程序设计语言类别的语句:数据定义语言(DDL),数据操作语言(DML)及数据控制语言(DCL)还有事务控制语言(TCL). ※  数据定义语言(DDL),例如:CREATE.DROP.ALTER等语句. ※  数据操作语言(DML),例如:INSERT(插入).UPDATE(修改).DELETE(删除)语句. ※  数据查询语言(DQL),例如:SELECT语句.(一般不会单独归于一类,因为只有一个语句). ※  数据控制语言(DCL),例如:GRANT.REVOKE等语

MySQL学习笔记_4_MySQL创建数据表(下)

 MySQL创建数据表(下) 五.数据表类型及存储位置 1.MySQL与大多数数据库不同,MySQL有一个存储引擎概念.MySQL可以针对不同的存储需求选择不同的存储引擎. 2. showengines; #查看MySQL所支持的存储引擎storageengine 3. showvariables like 'table_type'; #查看默认数据表类型 MyISAM和InnoDB最常用的存储引擎[表类型] 4.指定表类型[使用哪一个存储引擎]: createtable ...() eng