0

0

MySQL基本使用(二)之DCL语句和聚合函数

coldplay.xixi

coldplay.xixi

发布时间:2020-09-05 17:14:16

|

2767人浏览过

|

来源于xueyuanjun

转载

MySQL基本使用(二)之DCL语句和聚合函数

【相关学习推荐:mysql教程(视频)】

DCL

DCL 比较简单,主要用于授予或收回访问数据库的权限,以及数据库事务的提交和回滚。

授予/收回权限

以授予权限为例,我们新建一个数据库后,想要授予特定用户该数据库的访问和操作权限(一般在生产环境为了安全起见,不会通过 root 用户操作数据库),为此我们先要创建一个特定用户,比如 test,DCL 这种控制级的 SQL 语句一般在命令行执行,我们进入 MySQL Docker 容器,连接到数据库,通过 CREATE USER 语句新建一个 test 用户,同时将密码设置为 test

创建新用户

创建完成后,就可以在 mysql.user 数据表中看到这个用户了:

查看新用户

Host 字段为 % 表示 test 用户可以从任何主机连接到 MySQL 服务器。

或者通过命令行查看(这里用到了 SQL 查询语句):

查看新用户

然后我们就可以运行 GRANT 语句授予 test 用户对 test 数据库的所有操作权限了:

授予新用户权限

授权后,需要运行 flush privileges; 刷新权限,这样就可以在 test 数据库的权限列表中看到这个用户了:

查看新用户权限

如果我们退出当前登录状态,以 test 用户登录,就只能看到 test 数据库,因为它对其他数据库没有操作权限:

通过新用户连接MySQL

要撤回权限,需要以 root 身份进行,在权限列表删除这个用户,或者在命令行通过 REVOKE 语句完成:

revoke all privideges on test.* from 'test'@'%';
flush privileges;

这里操作的都是所有权限,也可以指定特定的权限:

// 授予权限
grant select on test.* to 'user1'@'localhost';  /*给予查询权限*/
grant insert on test.* to 'user1'@'localhost'; /*添加插入权限*/
grant delete on test.* to 'user1'@'localhost'; /*添加删除权限*/
grant update on test.* to 'user1'@'localhost'; /*添加权限*/

// 收回权限
revoke select on test.* from 'jack'@'localhost';
revoke insert on test.* from 'jack'@'localhost';
revoke delete on test.* from 'jack'@'localhost';
revoke update on test.* from 'jack'@'localhost';

事务提交/回滚

数据库事务(Database Transaction)是指作为单个逻辑工作单元执行的一系列操作(对数据库的相关增删改查的操作,包含一条或多条 SQL 语句),要么完全地执行,要么完全地不执行。

对于单条 SQL 语句,数据库系统自动将其作为一个事务执行,这种事务被称为隐式事务

要手动把多条 SQL 语句作为一个事务执行,可以使用 BEGIN 开启一个事务,使用 COMMIT 提交一个事务,这种事务被称为显式事务,如果事务执行过程中出现错误或异常,可以通过 ROLLBACK 语句回滚事务。

我们在命令行中简单演示下数据库事务的操作:

数据库事务演示

我们通过 BEGIN 语句开启事务,但是在执行多条语句后,没有通过 COMMIT 提交事务,测试执行这几条 SQL 语句,进入「浏览」面板查看,发现并没有插入新的记录:

数据库事务演示

如果在上述 SQL 序列后加上 ROLLBACK 回滚事务,效果也是一样的:

BEGIN;

INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章2', '测试内容哈哈哈', '2020-05-26 13:00:00');
INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章3', '测试内容哈哈哈', '2020-05-26 13:30:00');

ROLLBACK;

而如果在最后加上 COMMIT 语句,则可以顺利提交修改:

数据库事务提交演示

数据库事务提交演示

关于常见的 SQL 语句和 phpMyAdmin 中的可视化演示,就简单介绍到这里,更多细节,需要大家结合网上的 SQL 教程自己去探索,这不是本系列教程的重点,这里就不详细展开了。

PhotoScissors
PhotoScissors

免费自动图片背景去除

下载

聚合函数

除了常见的 SQL 查询和操作语句之外,SQL 还内置了一些聚合函数,方便在数据查询时对结果进行简单便捷的统计。这里我们介绍几个常见的函数:countsumavgmaxmin

COUNT

count 函数可用于统计查询结果总共有多少条,通常在进行分页查询时需要用到这个函数。为了方便直接看到结果,我们在命令行中进行演示:

count统计

在查询字段时为了提高可读性,可以通过 as 指定字段别名,这里 post 表总共有三条记录,所以查询结果是 3

SUM

sum 可用于统计查询结果中某个字段的求和,因此只能用于数字类型字段,这里我们为 post 表新增一个字段 views,用于存储对应文章记录的浏览次数。在 post 表结构中,选择在 content 字段后新增一个字段并点击「执行」:

新增数据表字段

将字段名设置为 views,并将其类型设置为 UNSIGNED INT,表示非负整数,同时设置默认值为 0,对应的 SQL 语句可以通过预览功能查看:

新增数据表字段

点击「保存」创建这个字段,就可以在表结构中看到它了:

新增数据表字段

由于 views 有默认值,所以目前所有记录的 views 值都是 0:

新增数据表字段默认值

可以通过「编辑」功能将其设置为对应的模拟值:

修改数据表字段值

接下来,我们就可以通过 sum 函数对结果进行求和统计了:

sum统计

AVG

avg 可用于统计查询结果中某个字段的平均值,和 sum 一样,也是作用于数字类型字段,比如我们可以通过它来统计所有文章的平均浏览数:

avg统计

如果是一个不能被整除的数字,平均数会精确到小数点后四位。

MAX

max 可用于获取查询结果中某个数字类型字段的最大值,比如要获取浏览数最高的文章信息可以这么做:

max查询

MySQL 命令行默认中文乱码,我们可以通过 set names utf8mb4; 将编码类型设置为 utf8mb4,这样就可以正常显示中文和 Emoji 表情符号了。

另外,这里还用到了子查询的概念,就是将一个查询的结果作为另一个查询的条件,这里我们将最大浏览数作为子查询的结果传递给父查询作为查询条件,获取对应的文章信息。

MIN

max 相对,min 函数用于获取查询结果中某个数字类型字段的最小值,比如要获取浏览数最低的文章信息可以这么做:

min查询

小结

好了,关于 MySQL 数据库的基本查询、操作和统计,我们就简单介绍到这里,相信你已经对 MySQL 及其操作有了基本的认知。下篇教程,将给大家介绍如何在 PHP 中连接 MySQL 数据库并执行增删改查操作,关于一些更复杂的操作,比如分页、分组、连接查询、关联关系、索引设置和应用,我们将在后续教程中结合具体实例进行演示。

本文来自于https://xueyuanjun.com/post/21656

想了解更多相关文章,敬请关注php mysql栏目!

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2890

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1731

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1564

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1099

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1546

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1649

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1309

2023.11.13

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 810人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号