Day04 03-MySQL数据库的DCL(用户|权限|视图)

这篇具有很好参考价值的文章主要介绍了Day04 03-MySQL数据库的DCL(用户|权限|视图)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

第十二章 DCL

12.1 DCL的作用

DCL语句主要用来做用户的创建、管理,权限的授予、撤销等操作的。

12.2 管理用户

创建、删除用户的操作,必须要使用root用户才可以完成!

-- 创建用户语法:
create user username@ip identified by 'password';

-- 修改用户密码:
alter user username@ip identified by 'newPassword';
set password for username@ip = password('newPassword');

-- 删除用户:
drop user username@ip
12.3 权限管理
-- 查看用户权限:使用超级管理员root
show grants for username

-- 授权:使用超级管理员root
grant 权限名[,权限名.....] on dbname.* to username@ip

-- DDL权限:create、alter、create view.....,drop
-- DML权限:insert、update、delete
-- DQL权限: select

-- 案例:授于某用户全部权限
grant all privileges on *.* to 'scott'@'localhost' identified by '123456' with grant option;
-- 案例:启用root用户的远程连接操作
-- 8.0之前版本: grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option;
create user 'root'@'%' identified by '123456';
grant all privileges on *.* to 'root'@'%' with grant option;

-- 撤销权限
revoke 权限名 [,权限名.....] on dbname.* from username@ip

-- 刷新权限
flush privilages;

如果在授权远程登录的时候,出现如下问题:

Unable to load authentication plugin ‘caching_sha2_password’

原因: 是因为mysql8使用的是caching_sha2_password加密规则。

解决:

  • alter user ‘test’@’%’ identified with mysql_native_password by ‘123456’;
  • 修改my.cnf文件,在末尾添加: default_authentication_plugin=mysql_native_password
12.4 视图

一张数据表中的数据有很多很多,会涉及到很多的行,涉及到很多的列。那么,如果我只希望其中的一部分数据被某一个用户能够查询到或者能够修改,应该怎么做呢?

此时,可以借助视图来实现这样的效果。

所谓视图,可以理解为一张表的映射,映射出这张表的一部分的数据。可以通过视图查询到原数据表中的一部分数据,也可以进行数据的插入、修改、删除的操作。文章来源地址https://www.toymoban.com/news/detail-469593.html

-- 创建视图
create view `v_emp` as select `empno`, `ename`, `sal`, `deptno` from `emp`;

-- 删除视图
drop view if exists `v_emp`;

到了这里,关于Day04 03-MySQL数据库的DCL(用户|权限|视图)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据库MySQL(三):DML、DQL、DCL

    数据操作语言(Data Manipulation Language,DML) 该语言主要对数据库表中的数据进行增删改 数据查询语言(Data Query Language,DQL) 该语言主要用于查询数据库表的记录 命令格式 SELECT [DISTINCT]    字段1 [AS 字段别名], [字段2 [AS 字段别名]], … FROM    表名列表 WHERE    条件

    2024年02月08日
    浏览(47)
  • 开源数据库Mysql_DBA运维实战 (DCL/日志)

      SQL(Structured Query Language 即结构化查询语言) a.DDL语句   数据库定义语言: 数据库,表,视图,索引,存储过程,函数,创建删除ALTER(CREATE DROP ALTER)  b.DML语句 数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE c.DQL语句   数据库查询语言:查询数据SELECT d.

    2024年02月12日
    浏览(84)
  • 【数据库 - 用户权限管理】(简略)

    目录 一、概述 二、用户权限类型 1.ALL PRIVILEGES 2.CREATE 3.DROP 4.SELECT 5.INSERT 6.UPDATE 7.DELETE 8.INDEX 9.ALTER 10.CREATE VIEW和CREATE ROUTINE 11.SHUTDOWN 12GRANT OPTION 三、语句格式 1.用户赋权 2.权限删除 3.用户删除 数据库用户权限管理是数据库系统中非常重要的一个方面,它用于控制不同用户访问

    2024年02月15日
    浏览(37)
  • Camunda8微服务流程引擎搭建实战 -- camunda-identity接入keycloak,使用mysql数据库以OpenID Connect的方式实现用户的权限管理

    准备需要: docker最新版,camunda官方建议使用容器且最好能使用k8s,而且jar包启动失败时不能停止 mysql8.0+,keycloak默认使用postgresql,我不会 提前启动好其他组件,es,tasklis,operate,zeebe,偷个懒,我使用的jar包运行,也可以容器 组件下载地址,版本8.3.4 因为容器通信的问题(应该是通信/网络的

    2024年01月19日
    浏览(55)
  • oracle数据库给用户授权DBA权限&Oracle查看哪些用户具有DBA权限

    步骤一:以sysdba身份登录到Oracle数据库 在授予DBA权限之前,我们首先要以sysdba身份登录到Oracle数据库。使用以下命令登录: 步骤二:创建用户(如有用户跳过) 要授予DBA权限,首先需要创建一个新用户。使用以下命令创建一个新用户: 步骤三:授予DBA权限 一旦用户创建成

    2024年02月09日
    浏览(54)
  • Postgresql创建用户与数据库并赋予权限

    1、使用postgres登录pgsql 2、添加名为iuser的用户,并设置密码 3、给iuser用户,创建数据库叫work_base 4、授予iuser当前work_base的全部权限 4.1、 先退出postgre数据库 4.2、登录work_base数据库 4.3、将work_base的所有权限赋予iuser

    2024年01月22日
    浏览(55)
  • openGauss学习笔记-108 openGauss 数据库管理-管理用户及权限-用户

    使用CREATE USER和ALTER USER可以创建和管理数据库用户。openGauss包含一个或多个已命名数据库。用户和角色在整个openGauss范围内是共享的,但是其数据并不共享。即用户可以连接任何数据库,但当连接成功后,任何用户都只能访问连接请求里声明的那个数据库。 非 三权分立 下,

    2024年02月08日
    浏览(59)
  • MariaDB 使用 root 账户管理数据库用户权限和远程登录权限设置

    MariaDB 使用 root 账户管理数据库用户权限和远程登录权限设置 作为一种流行的关系型数据库管理系统,MariaDB 提供了丰富的功能和灵活的权限控制机制。在本文中,我们将学习如何使用 root 账户来创建新用户,并为其分配特定的数据库权限和远程登录权限。 首先,我们需要使

    2024年01月23日
    浏览(51)
  • openGauss学习笔记-105 openGauss 数据库管理-管理用户及权限-默认权限机制

    数据库对象创建后,进行对象创建的用户就是该对象的所有者。openGauss安装后的默认情况下,未开启 三权分立 ,数据库系统管理员具有与对象所有者相同的权限。也就是说对象创建后,默认只有对象所有者或者系统管理员可以查询、修改和销毁对象,以及通过 GRANT 将对象的

    2024年02月07日
    浏览(56)
  • 【Spring Boot项目】根据用户的角色控制数据库访问权限

    在一些特定的业务需求下,要求创建只读用户,但是由于一些查询请求使用的是POST方法,因此在网关层面配置只允许请求GET方法又无法满足。所以就想到了是否可以在 JDBC 层面控制,判断角色并且只允许执行 SELECT 类型的SQL语句。 在Spring Boot项目中,我们可以通过结合网关和

    2024年02月06日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包