从零开始学数据库(二)——select显示、where、%、排序、limit、distinct、count、max等、删和改

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: (十一)使用select显示 输入: select * fromsales_rep where commission>1; 显示: mysql>select * from sales_rep where commission>1; +-----------------+---------+------------+------------+ |employes

(十一)使用select显示

输入:

select * fromsales_rep where commission>1;

显示:

mysql>select * from sales_rep where commission>1;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               1 | Rive    | Sol       |         10 |

|               2 | John    | char      |         11 |

|               3 | Jop     | Peter      |        12 |

|               4 | dong    | wang      |         20 |

|               6 | bbb     | BB         |          2 |

|               7 | ccc     | CC         |          3 |

|               8 | ddd     | DDD        |          4 |

|               9 | ee      | EEEE       |          5 |

|              10 | ff      | FFF        |          6 |

+-----------------+---------+------------+------------+

9rows in set (0.00 sec)

 

解释:

①select:表示使用select语句

②*:表示通配符(显示所有的)。可以用某一项替换,如surname,则只显示surname这一项;

③from sales_rep:指从表名为sales_rep的这一张表读取内容;

④where commission>1:指的是,读取表内commission这一个属性大于1的所有项;

也可以改为:where first_name='cc' :那么就只显示first_name的值是cc的项了(注意需要加引号)(并且不区分大小写,注意,mysql几乎是不区分大小写的)

⑤;:以分号为结尾。

 

 

 

(十二)where从句

基于(十一)

输入:

select * fromsales_rep where first_name!='cc' or first_name="cc";

显示:

mysql>select * from sales_rep where first_name!='cc' or first_name="cc";

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               1 | Rive    | Sol       |         10 |

|               2 | John    | char      |         11 |

|               3 | Jop     | Peter      |        12 |

|               4 | dong    | wang      |         20 |

|               5 | aaa     | AAA        |          1 |

|               6 | bbb     | BB         |          2 |

|               7 | ccc     | CC         |          3 |

|               8 | ddd     | DDD        |          4 |

|               9 | ee      | EEEE       |          5 |

|              10 | ff      | FFF        |          6 |

+-----------------+---------+------------+------------+

10rows in set (0.00 sec)

 

解释:

①or:前后各有一条语句first_name!='cc'first_name="cc"

②or的效果是两条语句只要有一条成立,便符合条件。由于一个内容要么是cc,要么不是cc(必然的),所以每一项都会成立(因此相当于显示除了null)。

③and:也可以用and来连接,表示两条语句都符合的才行。(有一条不符合就不成立)。

④多个or和and联用:支持联用。

or的联用:mysql> select * fromsales_rep where first_name='bb'or first_name="cc"orfirst_name="aaa";  三者符合一个的就可以。

and联用:由此可推,可以多个and联用。

也可以or和and混合使用,但为了避免理解出错,请使用括号来区分层级。

 

 

 

 

(十三)通配符%

%是一个通配符,类似*,表示0个或者多个字符。

输入:

select * fromsales_rep where first_name like "%c%";

显示:

mysql>select * from sales_rep where first_name like "%c%";

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               2 | John    | char      |         11 |

|               7 | ccc     | CC         |          3 |

+-----------------+---------+------------+------------+

2rows in set (0.00 sec)

 

效果:

first_name属性里有c字母的项,全部都是符合条件的。

 

 

 

(十四)分类

排序:(正序)

输入:

select * fromsales_rep order by first_name;

显示:

mysql>select * from sales_rep order by first_name;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               0 | NULL    | NULL      |       NULL |

|               8 | NULL    | NULL      |       NULL |

|               5 | aaa     | AAA        |          1 |

|               6 | bbb     | BB         |          2 |

|               7 | ccc     | CC         |          3 |

|               2 | John    | char      |         11 |

|               8 | ddd     | DDD        |          4 |

|               9 | ee      | EEEE       |          5 |

|              10 | ff      | FFF        |          6 |

|               3 | Jop     | Peter      |        12 |

|               1 | Rive    | Sol       |         10 |

|               4 | dong    | wang      |         20 |

+-----------------+---------+------------+------------+

15rows in set (0.00 sec)

 

效果:

在first_name项,以字母顺序进行排序(会显示null项);

 

 

 

排序:(多重排序)

输入:

select * fromsales_rep order by surname,first_name;

显示:

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               0 | NULL    | NULL      |       NULL |

|               8 | NULL    | NULL      |       NULL |

|               5 | aaa     | AAA        |          1 |

|               5 | bbb     | AAA        |          5 |

|               6 | bbb     | BB         |          2 |

|               7 | ccc     | CC         |          3 |

|               8 | ddd     | DDD        |          4 |

|               4 | dong    | wang      |         20 |

|               9 | ee      | EEEE       |          5 |

|              10 | ff      | FFF        |          6 |

|               2 | John    | char      |         11 |

|               3 | Jop     | Peter      |        12 |

|               1 | Rive    | Sol       |         10 |

+-----------------+---------+------------+------------+

16 rows in set (0.00 sec)

效果说明:

①多了一个surname作为参数。效果是,先以第一个参数所在的项为顺序进行排序显示,假如第一个一样,以第二个参数进行排序;

②由此类推,可以有更多项。

 

 

 

排序:(倒序)

输入:

select * fromsales_rep order by first_name desc;

显示:

mysql>select * from sales_rep order by first_name desc;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               4 | dong   | wang       |         20 |

|               1 | Rive    | Sol       |         10 |

|               3 | Jop     | Peter      |        12 |

|              10 | ff      | FFF        |          6 |

|               9 | ee      | EEEE       |         5 |

|               8 | ddd     | DDD        |          4 |

|               2 | John    | char      |         11 |

|               7 | ccc     | CC         |          3 |

|               6 | bbb     | BB         |          2 |

|               5 | bbb     | AAA        |          5 |

|               5 | aaa     | AAA        |          1 |

|               0 | NULL    | NULL      |       NULL |

|               8 | NULL    | NULL      |       NULL |

+-----------------+---------+------------+------------+

16rows in set (0.00 sec)

区别:

在正序的命令后面加一个desc即可。

 

 

 

排序:(正序关键字)

假如需要第一个参数按正序,相同的情况下,第二个参数按反序进行排列。

输入:

select * fromsales_rep order by surname asc, employes_number desc;

显示:

mysql>select * from sales_rep order by surname asc, employes_number desc;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|              10 | NULL    | NULL      |       NULL |

|               9 | NULL    | NULL      |       NULL |

|               8 | NULL    | NULL      |       NULL |

|               0 | NULL    | NULL      |       NULL |

|               0 | NULL    | NULL      |       NULL |

|               5 | aaa     | AAA        |          1 |

|               6 | bbb     | BB         |          2 |

|               5 | bbb     | AAA        |          5 |

|               7 | ccc     | CC         |          3 |

|               8 | ddd     | DDD        |          4 |

|               4 | dong    | wang      |         20 |

|               9 | ee      | EEEE       |          5 |

|              10 | ff      | FFF        |          6 |

|               2 | John    | char      |         11 |

|               3 | Jop     | Peter      |        12 |

|               1 | Rive    | Sol       |         10 |

+-----------------+---------+------------+------------+

16rows in set (0.00 sec)

 

 

 

(十五)限制返回的项数LIMIT

输出行数限制:

输入:(在排序:(正序关键字)基础上修改)

select * from sales_rep order by surname asc, employes_number desclimit 1;

显示:

mysql>select * from sales_rep order by surname asc, employes_number desc limit

1;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|              10 | NULL    | NULL      |       NULL |

+-----------------+---------+------------+------------+

1row in set (0.00 sec)

 

解释:

①limit可以设置为0(虽然不显示内容,但是可以用于在大的数据库中进行测试查询);

②limit后面的数字决定了返回的行数;

 

 

输出行数限制+偏移限制:

输入:

select * fromsales_rep order by surname asc, employes_number desc limit 1,2;

显示:

mysql>select * from sales_rep order by surname asc, employes_number desc limit

1,2;

+-----------------+---------+------------+------------+

|employes_number | surname | first_name | commission |

+-----------------+---------+------------+------------+

|               9 | NULL    | NULL      |       NULL |

|               8 | NULL    | NULL      |       NULL |

+-----------------+---------+------------+------------+

2rows in set (0.00 sec)

解释:

①参数1表示从开始偏移几行(即从理论应该显示的结果的第几行开始显示);

②参数2表示显示几行。

③1,2表示从第2行(偏移1)开始显示,显示2行

 

 

 

 

(十六)返回最大值MAX()

输入:

selectmax(commission) from sales_rep;

显示:

mysql>select max(commission) from sales_rep;

+-----------------+

|max(commission) |

+-----------------+

|              20 |

+-----------------+

1row in set (0.00 sec)

效果:

返回commission这一项中最大的值。(对字母也有效)

 

 

 

(十七)防止显示重复记录distinct

输入:

selectdistinct first_name from sales_rep;

显示:

mysql>select distinct first_name from sales_rep;

+------------+

|first_name |

+------------+

|Sol        |

|char       |

|Peter      |

|wang       |

|AAA        |

|BB         |

|CC         |

|NULL       |

|DDD        |

|EEEE       |

|FFF        |

+------------+

11rows in set (0.00 sec)

效果:

①原本都个NULL,这里只显示一个了;

②原本2个AAA,这里只显示一个了;

 

 

 

(十八)计数count()

显示有效数据的行数(不显示null):

输入:

selectcount(first_name) from sales_rep;

显示:

mysql>select count(first_name) from sales_rep;

+-------------------+

|count(first_name) |

+-------------------+

|                11 |

+-------------------+

1row in set (0.00 sec)

效果:

①除了null都显示;

 

 

显示所有数据的行数(貌似除非都是null,否则就显示):

输入:

selectcount(*) from sales_rep;

显示:

mysql>select count(*) from sales_rep;

+----------+

|count(*) |

+----------+

|       16 |

+----------+

1row in set (0.00 sec)

效果:

①即使有一项是null(其他项不是),也被计算在内;

 

 

显示行数:(重复项算一项,使用distinct)

输入:

selectcount(distinct first_name) from sales_rep;

显示:

mysql>select count(distinct first_name) from sales_rep;

+----------------------------+

|count(distinct first_name) |

+----------------------------+

|                         10 |

+----------------------------+

1row in set (0.00 sec)

效果:

①该项(first_name)中如果有重复的,记作一项。

 

 

(十九)平均、最小、总和

平均:avg()

最小:min()

总和:sum()

 

输入:

selectsum(commission) from sales_rep;

显示:

mysql>select sum(commission) from sales_rep;

+-----------------+

|sum(commission) |

+-----------------+

|              79 |

+-----------------+

1row in set (0.00 sec)

 

效果:

①三个方法类似,结果不同;

②对字符串无效

 

 

 

(二十)对计算结果修改(不影响原数据)

输入:

selectemployes_number ,surname, commission+100 from sales_rep;

显示:

mysql>select employes_number ,surname, commission+100 from sales_rep;

+-----------------+---------+----------------+

|employes_number | surname | commission+100 |

+-----------------+---------+----------------+

|               1 | Rive    |           110 |

|               2 | John    |           111 |

|               3 | Jop     |            112 |

|               4 | dong    |           120 |

|               5 | aaa     |            101 |

|               6 | bbb     |            102 |

|               7 | ccc     |            103 |

|               8 | NULL    |          NULL |

|               9 | NULL    |          NULL |

|              10 | NULL    |          NULL |

|               0 | NULL    |          NULL |

|               8 | ddd     |            104 |

|               9 | ee      |            105 |

|              10 | ff      |            106 |

|               0 | NULL    |          NULL |

|               5 | bbb     |            105 |

+-----------------+---------+----------------+

16rows in set (0.00 sec)

 

效果:

①指定项显示结果 + 100,(commission+100);

②显示选择的项(employes_number ,surname,commission);

③不影响原数据;

 

 

 

(二十一)删除记录

输入:

delete fromsales_rep where surname="aaa";

显示:

mysql> delete from sales_rep where surname="aaa";

Query OK, 1 row affected (0.06 sec)

 

效果:

①删除值为null的项:delete fromsales_rep where surname is null;

②删除记录将删除所有符合要求的(所以尽量使用唯一项,例如类似id的东西);

③假如输入delete from sales_rep 将删除所有项

 

 

 

(二十二)修改记录

输入:

updatesales_rep set commission = 20 where employes_number=1;

显示:

mysql> update sales_rep set commission = 20 where employes_number=1;

Query OK, 1 row affected (0.06 sec)

Rows matched: 1  Changed: 1  Warnings: 0

效果:

①employes_number的值是1的项,其commission的值被更改为20。

 

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
关系型数据库 MySQL 数据库
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
139 0
|
5月前
|
SQL 关系型数据库 MySQL
MySQL数据库——SQL优化(3/3)-limit 优化、count 优化、update 优化、SQL优化 小结
MySQL数据库——SQL优化(3/3)-limit 优化、count 优化、update 优化、SQL优化 小结
303 0
|
SQL 关系型数据库 MySQL
MySQL防止重复插入(数据库层where方法解决)
MySQL防止重复插入(数据库层where方法解决)
38 0
|
SQL 数据库
数据库sql语句(count(*)和count(字段))
数据库sql语句(count(*)和count(字段))
183 0
|
存储 数据库
数据库 HAVING COUNT () 的用法
数据库 HAVING COUNT () 的用法
445 0
数据库 HAVING COUNT () 的用法
|
SQL 关系型数据库 MySQL
MySQL 数据库sql语句用关键字作为where条件进行筛选实例演示,mysql建表、查询字段为关键字解决方法
MySQL 数据库sql语句用关键字作为where条件进行筛选实例演示,mysql建表、查询字段为关键字解决方法
235 0
MySQL 数据库sql语句用关键字作为where条件进行筛选实例演示,mysql建表、查询字段为关键字解决方法
|
SQL 关系型数据库 MySQL
MySQL 数据库show processlist where条件筛选报错解决方法,[Code: 1064, SQL State: 42000] You have an error in your
MySQL 数据库show processlist where条件筛选报错解决方法,[Code: 1064, SQL State: 42000] You have an error in your
547 0
MySQL 数据库show processlist where条件筛选报错解决方法,[Code: 1064, SQL State: 42000]  You have an error in your
|
关系型数据库 MySQL 数据库
MySQL数据库——where查询
使用where子句实现对查询数据的筛选 where子句分为五类: 比较运算符 逻辑运算符 范围查询 模糊查询 空判断
199 0
|
关系型数据库 MySQL 数据库
数据库面试题【十九、count(字段) &count(主键 id) &count(1)&count(*)的区别】
数据库面试题【十九、count(字段) &count(主键 id) &count(1)&count(*)的区别】
171 0
下一篇
无影云桌面