MySQL基础-----SQL语句之DCL数据控制语句

 目录

前言

一、管理用户

1.查询用户

2.创建用户

3.修改用户密码

4.删除用户

案例

二、权限控制

1.查询权限

 2.授予权限

 3.撤销权限

案例


前言

        本期我们学习SQL语句的最后一部分内容,也就是数据控制语句DCL。DCL英文全称是Data Control Language(数据控制语言),用来管理数据库用户、控制数据库的访问权限。

一、管理用户

1.查询用户

select * from mysql.user;

 查询结果如下:

其中 Host 代表当前用户访问的主机 , 如果为 localhost, 仅代表只能够在当前本机访问,是不可以
远程访问的。 User 代表的是访问该数据库的用户名。在 MySQL 中需要通过 Host User 来唯一标识一个用户。

2.创建用户

CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

 3.修改用户密码

ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码' ;

4.删除用户

DROP USER '用户名'@'主机名' ;
注意事项:
  • 在MySQL中需要通过用户名@主机名的方式,来唯一标识一个用户。
  •  主机名可以使用 % 通配。
  •  这类SQL开发人员操作的比较少,主要是DBA( Database Administrator 数据库 管理员)使用。

案例

A. 创建用户itcast, 只能够在当前主机localhost访问, 密码123456

create user 'itcast'@'localhost' identified by '123456';

创建后查看用户,多了一个名字为itcast的用户,同时登录试试看。

 B. 创建用户ikun, 可以在任意主机访问该数据库, 密码123456;

create user 'ikun'@'%' identified by '123456';

查询后,可以看到这里多了一个ikun 的用户

C. 修改用户ikun的访问密码为1234;

alter user 'ikun'@'%' identified with mysql_native_password by '1234';

修改后测试登录,登录成功

D. 删除 itcast@localhost 用户

drop user 'itcast'@'localhost';

 执行后,查询当前已有用户,如下所示,itcast用户被删除了

二、权限控制

MySQL中定义了很多种权限,但是常用的就以下几种:

权限

说明

ALL, ALL PRIVILEGES

所有权限

SELECT

查询数据

INSERT

插入数据

UPDATE

修改数据

DELETE

删除数据

ALTER

修改表

DROP

删除数据库/表/视图

CREATE

创建数据库/表

 上述只是简单罗列了常见的几种权限描述,其他权限描述及含义,可以直接参考官方文档(MySQL :: MySQL 8.0 Reference Manual :: 8.2.2 Privileges Provided by MySQL

1.查询权限

SHOW GRANTS FOR '用户名'@'主机名' ; 1

 2.授予权限

GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';

 3.撤销权限

REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名'; 1
注意事项:
  • 多个权限之间,使用逗号分隔
  •  授权时, 数据库名和表名可以使用 * 进行通配,代表所有。

案例

A. 查询 'ikun'@'%' 用户的权限
show grants for 'ikun'@'%';

 B. 授予 'ikun'@'%' 用户itcast数据库所有表的所有操作权限

grant all on itcast.* to 'ikun'@'%';

再次查询权限

 C. 撤销 'ikun'@'%' 用户的itcast数据库的所有权限

revoke all on itcast.* from 'ikun'@'%';

再次查询权限

 以上是本期全部的内容,我们下一期就开始学习函数了,下次见!

分享一张壁纸:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/519314.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java BigDecimal常用的方法介绍

在 Java 中,BigDecimal 类是一个用于高精度十进制浮点运算的类。与 double 和 float 类型相比,BigDecimal 提供了一个精确的十进制控制,并且在商业计算中非常重要,因为它可以避免由于浮点数精度不准确而导致的错误。 以下是 BigDe…

前端工程化【01】:核心思想、发展历程和面临挑战

前端工程化是指将前端开发中的工具、流程和方法进行规范化和自动化,以提高前端开发效率、提升代码质量和项目可维护性的一种开发方式。通过前端工程化,可以将前端开发过程中的重复工作自动化,减少开发者的重复劳动,提高开发效率。…

谷粒学院--在线教育实战项目【一】

谷粒学院--在线教育实战项目【一】 一、项目概述1.1.项目来源1.2.功能简介1.3.技术架构 二、Mybatis-Plus概述2.1.简介2.2.特性 三、Mybatis-Plus入门3.1.创建数据库3.2.创建 User 表3.3.初始化一个SpringBoot工程3.4.在Pom文件中引入SpringBoot和Mybatis-Plus相关依赖3.5.第一…

图机器学习(1)--导论

0 引入 为什么是图?图是描述关联数据的通用语言。 前期的研究:节点之间独立同分布,没有关系。 图:节点之间有关联关系。 0.1 图数据举例 0.2 问题描述 黏菌按照人类规划的铁路网进行生长。 复杂域具有丰富的关系结构&#xf…

开放式高实时高性能PLC控制器解决方案-基于米尔电子STM32MP135

前言 随着工业数字化进程加速与IT/OT深入融合,不断增加的OT核心数据已经逐步成为工业自动化行业的核心资产,而OT层数据具备高实时、高精度、冗余度高、数据量大等等特点,如何获取更加精准的OT数据对数字化进程起到至关重要的作用,…

虽说主业搞前端,看到如此漂亮的网页UI,也是挪不开眼呀。

漂亮的网页UI能够吸引人的眼球,给人留下深刻的印象。作为前端开发人员,可以通过不断学习和掌握设计技巧和工具,提升自己的UI设计能力,为用户提供更好的视觉体验。 以下是一些提升网页UI设计能力的建议: 学习设计基础知…

MySQL基础(未完待续...)

数据库基础 MySQL概述 数据库相关概念 名称作用简称数据库存储数据的仓库,数据是有组织的进行存储DataBase(DB)数据库管理系统操纵和管理数据库的大型软件DataBase Management System (DBMS)SQL操作关系型数据库的编程语言,定义…

个人项目介绍4:三维园区篇

个人项目介绍: 地图铁路线路篇 地球卫星篇 火车站篇 三维园区篇 项目需求: 1.按比例全景显示三维园区 2.精确显示园区内设备设施 3.实时显示设备报警信息 4.显示园区内摄像监控设备,并可点击显示监控视频流 5.显示园区内的重大危险源和风险分布 …

算法题 — 三个数的最大乘机

三个数的最大乘机 整型数组 nums,在数组中找出由三个数字组成的最大乘机,并输出这个乘积。(乘积不会越界) 重点考察:线性扫描 排序法: public static void main(String[] args) {System.out.println(so…

SpringMVC实用技术

1.校验框架 1.表单校验框架入门 表单校验的重要性 数据可以随意输入,导致错误的结果。表单校验保障了数据有效性、安全性 表单校验分类 校验位置: 客户端校验 服务端校验 校验内容与对应方式: 格式校验 客户端:使用Js技术…

MySQL学习Day24—数据库的设计规范

一、数据库设计的重要性: 1.糟糕的数据库设计产生的问题: (1)数据冗余、信息重复、存储空间浪费 (2)数据更新、插入、删除的异常 (3)无法正确表示信息 (4)丢失有效信息 (5)程序性能差 2.良好的数据库设计有以下优点: (1)节省数据的存储空间 (2)能够保证数据的完整性 …

多层菜单的实现方案(含HierarchicalDataTemplate使用)

1、递归 下面是Winform的递归添加菜单栏数据,数据设置好父子id方便递归使用 在TreeView的控件窗口加载时,调用递归加载菜单 private void LoadTvMenu(){this.nodeList objService.GetAllMenu(); // 通过Service得到全部数据// 创建一个根节点this.t…