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
数据库,因为它对其他数据库没有操作权限:
要撤回权限,需要以 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 教程自己去探索,这不是本系列教程的重点,这里就不详细展开了。
聚合函数
除了常见的 SQL 查询和操作语句之外,SQL 还内置了一些聚合函数,方便在数据查询时对结果进行简单便捷的统计。这里我们介绍几个常见的函数:count
、sum
、avg
、max
和 min
。
COUNT
count
函数可用于统计查询结果总共有多少条,通常在进行分页查询时需要用到这个函数。为了方便直接看到结果,我们在命令行中进行演示:
在查询字段时为了提高可读性,可以通过 as
指定字段别名,这里 post
表总共有三条记录,所以查询结果是 3
。
SUM
sum
可用于统计查询结果中某个字段的求和,因此只能用于数字类型字段,这里我们为 post
表新增一个字段 views
,用于存储对应文章记录的浏览次数。在 post
表结构中,选择在 content
字段后新增一个字段并点击「执行」:
将字段名设置为 views
,并将其类型设置为 UNSIGNED INT
,表示非负整数,同时设置默认值为 0
,对应的 SQL 语句可以通过预览功能查看:
点击「保存」创建这个字段,就可以在表结构中看到它了:
由于 views
有默认值,所以目前所有记录的 views
值都是 0:
可以通过「编辑」功能将其设置为对应的模拟值:
接下来,我们就可以通过 sum
函数对结果进行求和统计了:
AVG
avg
可用于统计查询结果中某个字段的平均值,和 sum
一样,也是作用于数字类型字段,比如我们可以通过它来统计所有文章的平均浏览数:
如果是一个不能被整除的数字,平均数会精确到小数点后四位。
MAX
max
可用于获取查询结果中某个数字类型字段的最大值,比如要获取浏览数最高的文章信息可以这么做:
MySQL 命令行默认中文乱码,我们可以通过 set names utf8mb4;
将编码类型设置为 utf8mb4
,这样就可以正常显示中文和 Emoji 表情符号了。
另外,这里还用到了子查询的概念,就是将一个查询的结果作为另一个查询的条件,这里我们将最大浏览数作为子查询的结果传递给父查询作为查询条件,获取对应的文章信息。
MIN
与 max
相对,min
函数用于获取查询结果中某个数字类型字段的最小值,比如要获取浏览数最低的文章信息可以这么做:
小结
好了,关于 MySQL 数据库的基本查询、操作和统计,我们就简单介绍到这里,相信你已经对 MySQL 及其操作有了基本的认知。下篇教程,将给大家介绍如何在 PHP 中连接 MySQL 数据库并执行增删改查操作,关于一些更复杂的操作,比如分页、分组、连接查询、关联关系、索引设置和应用,我们将在后续教程中结合具体实例进行演示。
本文来自于https://xueyuanjun.com/post/21656
想了解更多相关文章,敬请关注php mysql栏目!
以上是MySQL基本使用(二)之DCL语句和聚合函数的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

Navicat本身不存储数据库密码,只能找回加密后的密码。解决办法:1. 检查密码管理器;2. 检查Navicat的“记住密码”功能;3. 重置数据库密码;4. 联系数据库管理员。

使用 Navicat Premium 创建数据库:连接到数据库服务器并输入连接参数。右键单击服务器并选择“创建数据库”。输入新数据库的名称和指定字符集和排序规则。连接到新数据库并在“对象浏览器”中创建表。右键单击表并选择“插入数据”来插入数据。

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

Navicat 无法连接数据库的常见原因及其解决方法:1. 检查服务器运行状态;2. 核对连接信息;3. 调整防火墙设置;4. 配置远程访问;5. 排除网络问题;6. 检查权限;7. 保障版本兼容性;8. 排除其他可能性。

在 Navicat 中执行 SQL 的步骤:连接到数据库。创建 SQL 编辑器窗口。编写 SQL 查询或脚本。单击“运行”按钮执行查询或脚本。查看结果(如果执行查询的话)。

可在 Navicat 中通过以下步骤新建 MySQL 连接:打开应用程序并选择“新建连接”(Ctrl N)。选择“MySQL”作为连接类型。输入主机名/IP 地址、端口、用户名和密码。(可选)配置高级选项。保存连接并输入连接名称。

不同数据库系统添加列的语法为:mysql:alter table table_name add column_name data_type; postgresql:alter table table_name添加column_name data_type; oracle; oracle:alter table table_name add(column_name data_type)
