DCL是数据控制语言,用来管理数据库用户,还有控制用户的访问权限
data:image/s3,"s3://crabby-images/86445/8644553325c199aea429568799f8e8f886ed67fc" alt=""
1.用户的查询
MySQL的用户信息存储在mysql数据库中,查询用户时,我们需要使用这个数据库。
data:image/s3,"s3://crabby-images/c4d0b/c4d0b1cd2bfa5286c184189f54dbf3b086b2dceb" alt=""
data:image/s3,"s3://crabby-images/719ad/719adaa3d7ee085f6540c93d77ef213962f85f38" alt=""
后面,还有很多数据,因为篇幅的问题,就不过多赘述了。后面还有一个创建用户创建的时间
data:image/s3,"s3://crabby-images/a5eac/a5eacf5d2bca5a5772d74ebbe49a572deb80e026" alt=""
data:image/s3,"s3://crabby-images/fc269/fc269add014ca46c7613cc4b34bedecb60d4d93f" alt=""
localhost说明只能在本地访问这个数据库
data:image/s3,"s3://crabby-images/0c339/0c33978cf67272081f006590152ad4b87ac6382b" alt=""
data:image/s3,"s3://crabby-images/feaa3/feaa3b69ee72ce429ff3a6cb9cb7f56891064fc2" alt=""
我们可以使用lcy用户登录我们的mysql
data:image/s3,"s3://crabby-images/facfb/facfbb9cc6d98e122f7662714fa059d84de80bbd" alt=""
但是为什么lcy用户不能访问到其他数据库,这是因为,它没有访问其他数据库的权限
lcy用户只能在本地主机访问
那么怎么创建一个任何主机都可以访问的用户
下面我们创建一个cy用户,可以在任何主机访问数据库
data:image/s3,"s3://crabby-images/b5117/b5117bf0796f30bb3dcf700f96d35cadfc269230" alt=""
data:image/s3,"s3://crabby-images/94002/94002704cd3a041e3f70b1a164e24030826d1203" alt=""
当我们忘记用户的密码时,也可以修改用户的密码
语法
data:image/s3,"s3://crabby-images/62971/62971d6313f50393b5597e86e3f3486742682aae" alt=""
data:image/s3,"s3://crabby-images/cd15a/cd15a3f4e45807fc70d3edb9deaf836fe6856b5e" alt=""
data:image/s3,"s3://crabby-images/fcb2e/fcb2eba55bc80da6ba0fba23d8f8b2bc42f37e96" alt=""
不需要这个用户也可以删除用户
语法
data:image/s3,"s3://crabby-images/c9193/c9193d3734f978e707aa4d5475a9e274f616d182" alt=""
data:image/s3,"s3://crabby-images/8e1a9/8e1a91487d64c167747ad4444b6454da8fe6753d" alt=""
data:image/s3,"s3://crabby-images/dd2bf/dd2bf735502329ab23366ca61640714e65fa9d2d" alt=""
DCL 用户权力管理
data:image/s3,"s3://crabby-images/9fa2d/9fa2dac82e62ca978b8607f233e0c312bf6eea34" alt=""
data:image/s3,"s3://crabby-images/27818/278183ddd3817397f550c059c8193a7c28f2f6a3" alt=""
data:image/s3,"s3://crabby-images/b9920/b992065c057ea1cb6aaf858f19edfb9345f02358" alt=""
我们创建一个lcy用户,和上面用户得创建一样,查询它的权限
data:image/s3,"s3://crabby-images/fb669/fb669ca8636ff25333e99a0015561c1d67ee4660" alt=""
data:image/s3,"s3://crabby-images/cf9f8/cf9f84c0be40c5cd29fa94162000e31a8a373cf7" alt=""
可以看到lcy用户只有连接的权限。
那么我们怎么赋予权限呢
语法
data:image/s3,"s3://crabby-images/7c2b2/7c2b25b9d76c444d26a8136512e0dfe196fa643b" alt=""
在赋予权限之前,我们看一下它可以访问什么数据库
data:image/s3,"s3://crabby-images/6e0e1/6e0e144f7a6e9241df0b3156b61804fc753aadbb" alt=""
我们有一个test数据库,我们把它的所有权限给lcy用户
data:image/s3,"s3://crabby-images/4bddd/4bddd814b12fbfbf4aa0170da24b377f38aa9106" alt=""
这时lcy表就有test。数据库的所有权限了
data:image/s3,"s3://crabby-images/ff29a/ff29a3e8cb57977271b69f16959b87f6ce0ec963" alt=""
这个时候我们可以访问test数据库,查看看test数据库的所有表
我们也可以撤销授予的权限
语法
data:image/s3,"s3://crabby-images/78b12/78b12c8a85f436916db608d39dc6010bce1759d2" alt=""
data:image/s3,"s3://crabby-images/e475a/e475aca9de491f86e9dc399420251b49a7a4d4ff" alt=""
撤销权限后,查看到它没有权限。只能连接。
也可以通过查询数据库的方式查看
data:image/s3,"s3://crabby-images/ea90e/ea90e7282715b05722458f414a955abbfd294c4d" alt=""
注意事项:
• 多个权限之间,使用逗号分隔
• 授权时, 数据库名和表名可以使用 * 进行通配,代表所有。
总结
data:image/s3,"s3://crabby-images/ad5b7/ad5b77d32b5dcce2dd186f5d9ca688f5f391f8cd" alt=""