项目五 实现对学生信息的简单查询
1,查询数据库中部分字段的信息
使用select语句对表的选择及连接等操作,结构会生成一个临时表,将select结果存放到临时表中
查询数据表中所有字段的值
#格式:(*:表示所有列)
select * from 表名;
#检索出的列是未排序的,其显示是按 mysql 底层的存储顺序进行显示。
查询数据表中部分字段的值
#只查询一个字段
select 字段名 from 表名;
#查询多个字段
select 字段名 1,字段名 2......字段名 n from 表名;
#注意:每个字段名后用逗号隔开,但最后一个字段名后不加逗号。
查询数据表中表达式的值
1)#使用计算字段(就是字段之间,或数值之间的表达式)
mysql> select * from cj;
+------+------+------+------+------+
| id | name | sx | yw | yy |
+------+------+------+------+------+
| 1 | aa | 80 | 90 | 60 |
| 2 | bb | 86 | 96 | 66 |
| 3 | cc | 66 | 90 | 96 |
+------+------+------+------+------+
#查看总成绩
mysql> select name,sx+yw+yy from cj;
+------+----------+
| name | sx+yw+yy |
+------+----------+
| aa | 230 |
| bb | 248 |
| cc | 252 |
+------+----------+
#mysql 支持+ - * / 的基本运算,只是在显示结果,原数据并没有变
(2)#使用拼接字段(将多个值联结到一起构成单个值)
concat 函数使用方法: concat(参数 1,参数 2......参数 n)
#其中参数可以是表中的字段名或者加入的字符串,若为字符串,应用引号引起来
mysql> select concat(name,'(',yw,',',sx,',',yy,')') from cj;
+---------------------------------------+
| concat(name,'(',yw,',',sx,',',yy,')') |
+---------------------------------------+
| aa(90,80,60) |
| bb(96,86,66) |
| cc(90,66,96) |
+---------------------------------------+
#本例中,concat 函数连接了八部分内容,其中四个是字段名,左半括号、右半括号及两个逗号为字符。
定义容易理解的列别名
#格式:
select 字段名 [as] 列标题
mysql> select concat(StuName,'(',StuID,',',StuSex,')') from Student;
+------------------------------------------+
| concat(StuName,'(',StuID,',',StuSex,')') |
+------------------------------------------+
| 张林浩(150101,男) |
| 张林浩(150101,男) |
| 张林浩(150101,男) |
+------------------------------------------+
mysql> select concat(StuName,'(',StuID,',',StuSex,')') as info from Student;
+-----------------------+
| info |
+-----------------------+
| 张林浩(150101,男) |
| 张林浩(150101,男) |
| 张林浩(150101,男) |
+-----------------------+
#起别名时,只显示在临时表中,原表没变。如果别名标题有空格,要用单引号括起来,但如果含_.则不用单引号。
使用查询语句的输出功能
- select 语句可以从数据表中查询信息,但当不提供库时,就只完成输出功能
#例如:
mysql> select 'aa';
+----+
| aa |
+----+
| aa |
+----+
mysql> select '3*2' as 乘积;
+--------+
| 乘积 |
+--------+
| 3*2 |
+--------+
mysql> select now(); #当前时间
+---------------------+
| now() |
+---------------------+
| 2022-09-23 15:09:40 |
+---------------------+
2,根据指定条件进行查询
消除结果集中的重复行
#在字段名前加关键字distinct过滤相同值
语法:select distinct|distinctrow column_name [,column_name...]
#例如:查询生源地,去掉结果中的重复行
mysql> select distinct Native from Student;
#当检索多个字段时,必须每个字段的值都一样才认为是重复行
#即 distinct 用于后面的所有字段而不仅是紧跟在其后的字段。
实现有条件的筛选
MySQL中的运算符
1,where子句的使用
- 可以使用 where 子句和特定的 操作符来实现选择行的目的。
#语法:
select 字段名 1,字段名 2....字段名 n
from 表名
where 筛选条件;
#案例:查看所有男生的学号,姓名(字符串常量用单引号括起来)
select StuID,StuName,StuSex from Student where StuSex='男';
#between 操作符的使用方法为:
(not)between 表达式 1 and 表达式 2
#表示值在表达式 1 和表达式 2 之间,包含表达式 1 和表达式 2。
#案例:查询所有期末考试成绩在 80-90 之间的同学的成绩。
select * from Score
where ExamScore between 80 and 90;
2,where子句常使用的操作符:
- and操作符:两个或多个条件同时满足
- or操作符:满足多个条件中的任何一个即检索成功
- in操作符:满足多个条件中的一个
- like 操作符:配合%通配符和_通配符实现模糊查询
(1)#and操作符案例:
mysql> select *from Student where ClassID='mb1501' and StuSex='男';
(2)#or操作符案例(or前后必须是完整的条件)
mysql> select * from Student where Native='河北保定' or Native='河北石家庄';
(3)#in操作符案例
in 操作符的使用格式如下:(not) in (值 1,值 2,值 3....)
#其含义是使用 in 关键字可以指定一个值表,值表中列出所有可能的值,当与值表中的任一个匹配时,即返回 TRUE,否则返回 FALSE。
mysql> select * from Score where CourseID in ('10101','10102');
(4)#like 操作符与%通配符搭配使用(这是模糊查询),当其与%通配符搭配使用时,可实现匹配任意多个任意字符,包含零个字符。
mysql> select * from Student where StuName like '张%';
(5)#like 操作符与_通配符搭配使用
当 like 操作符与_通配符搭配使用时,可实现匹配任意单个字符。
#查询姓名为两个字的李姓同学。
mysql> select * from Student where StuName like '张__';
#注意事项:
1,根据 SQL 的配置方式,搜索可以是区分大小写的。
2,尾空格可能会干扰通配符,可在最后加一个%,或使用函数
3,%不能匹配 null,如使用 like ‘%’ 并不能搜索出结果中有 null 的行
4,不要过度使用,尽可能用其它操作符
5,除非绝对必要,否则不要放在开始处,因为速度最慢
6,小心通配符的位置,否则达不到效果
4、多个操作符时的计算次序
-
当 where 子句的条件中有多个操作符时,SQL 语言优先组合 and 操作符。
-
解决的办法是将优先组合的条件用括号括起来
mysql> select * from Student where (Native=河北保定’or Native=’河北石家庄’) and Stusex=’男’;
#如果条件语句意思不明确时,可以加入圆括号
3,完成对查询结果的排序
使用一个字段进行排序
#order by排序语句
ORDER BY {col_name | expr | position} [ASC | DESC] , ...
#ORDER BY 子句后可以是一个列、一个表达式或一个正整数。默认是按升序排列,即 ASC,如果想按某一列降序排列,则应指定 DESC。
#例如1:查询Student表中学生的学号和姓名,并按学号升序排列。
mysql> select StuID,StuName from Student order by StuID[ASC];
#例如2:查询 Score 表中 10101 课程的成绩,并按成绩降序排列
mysql> select * from Score where CourseID='10101' order by ExamScore DESC;
#mysql 中的 orber by 子句还可以用非检索的列来进行排序.
#例如3:查询 Student 表中的学生的姓名和性别并按学号升序排列。
mysql> select StuName,StuSex from Student order by StuID;
#order by 后面如果是正整数表示按检索结果中整数对应位置上的列进行排序。
使用多个字段进行排序
排序的规则是:若检索结果中第一个字不同,则按第一个字段排序,第一个字段相同时,再按第二个字段排序,依次类推。
#使用多字段排序的查询语句的书写方式为:
select 字段名 1,字段名 2,......字段名 n
from 表名
order by 字段名 1,字段名 2,......字段名 n
#即 order by 子句的各个字段名间用逗号隔开,最后一个字段后不加逗号。
#例如:查询 Score 表中的信息,按课程号降序排列,相同课程号按学号降序排列。
mysql> select * from Score order by CourseID DESC,StuID DESC;
#当 order by 后面有多个字段时,需逐个指定排序方向,即每个待排序字段后都要加关键字 ASC 或 DESC,否则未加关键字的字段将默认为 ASC。
4,实现分页查询的基础
- LIMIT 子句:主要用于限制被 SELECT 语句返回的行数
LIMIT {[offset,] row_count | row_count OFFSET offset}
#语法格式中的 offset 和 row count 都必须是非负的整数常数,offset 指定返回的第一行的偏移量,row count是返回的行数。值得注意的是初始行的偏移量为 0 而不是 1。
#例如:查询 Student 表中的前三个同学的信息
mysql> select * from Student limit 3;
#使用 limit 子句时,当实际记录数小于指定显示条数时,按实际记录数显示
#例如,“LIMIT 3”表示返回 SELECT 语句的结果集中最前面 3 行,而“LIMIT 5,3”则表示从第6 行开始返回 3 行
ount 都必须是非负的整数常数,offset 指定返回的第一行的偏移量,row count是返回的行数。值得注意的是初始行的偏移量为 0 而不是 1。
#例如:查询 Student 表中的前三个同学的信息
mysql> select * from Student limit 3;
#使用 limit 子句时,当实际记录数小于指定显示条数时,按实际记录数显示
```shell
#例如,“LIMIT 3”表示返回 SELECT 语句的结果集中最前面 3 行,而“LIMIT 5,3”则表示从第6 行开始返回 3 行