0

0

linux mysql更改用户权限

php中文网

php中文网

发布时间:2016-06-07 15:40:13

|

1435人浏览过

|

来源于php中文网

原创

mysql更改用户权限 This entry was posted by admin Monday, 26 April, 2010 1.“grant all on *.* toroot@’%’identified by ‘yourpassword’;”——这个还可以顺带设置密码。 2.“flush privileges; ”——刷新一下,让权限生效。 mysql的一些其他的管理

mysql更改用户权限

This entry was posted by admin Monday, 26 April, 2010

1.“grant all on *.* to root@’%’ identified by ‘yourpassword’;”——这个还可以顺带设置密码。
2.“flush privileges; ”——刷新一下,让权限生效。
mysql的一些其他的管理,可以用mysqladmin命令。可以用来设置密码什么的。


本文实例,运行于 MySQL 5.0 及以上版本。

MySQL 赋予用户权限命令的简单格式可概括为:

grant 权限 on 数据库对象 to 用户

一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。

grant select on testdb.* to common_user@’%’
grant insert on testdb.* to common_user@’%’
grant update on testdb.* to common_user@’%’
grant delete on testdb.* to common_user@’%’

或者,用一条 MySQL 命令来替代:

grant select, insert, update, delete on testdb.* to common_user@’%’

二、grant 数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限。

grant 创建、修改、删除 MySQL 数据表结构权限。

grant create on testdb.* to developer@’192.168.0.%’;
grant alter on testdb.* to developer@’192.168.0.%’;
grant drop   on testdb.* to developer@’192.168.0.%’;

grant 操作 MySQL 外键权限。

grant references on testdb.* to developer@’192.168.0.%’;

grant 操作 MySQL 临时表权限。

grant create temporary tables on testdb.* to developer@’192.168.0.%’;

grant 操作 MySQL 索引权限。

grant index on testdb.* to developer@’192.168.0.%’;

grant 操作 MySQL 视图、查看视图源代码 权限。

grant create view on testdb.* to developer@’192.168.0.%’;
grant show   view on testdb.* to developer@’192.168.0.%’;

grant 操作 MySQL 存储过程、函数 权限。

grant create routine on testdb.* to developer@’192.168.0.%’; — now, can show procedure status
grant alter routine on testdb.* to developer@’192.168.0.%’; — now, you can drop a procedure
grant execute        on testdb.* to developer@’192.168.0.%’;

三、grant 普通 DBA 管理某个 MySQL 数据库的权限。

grant all privileges on testdb to dba@’localhost’

其中,关键字 “privileges” 可以省略。
四、grant 高级 DBA 管理 MySQL 中所有数据库的权限。

grant all on *.* to dba@’localhost’

五、MySQL grant 权限,分别可以作用在多个层次上。

1. grant 作用在整个 MySQL 服务器上:

grant select on *.* to dba@localhost; — dba 可以查询 MySQL 中所有数据库中的表。
grant all    on *.* to dba@localhost; — dba 可以管理 MySQL 中的所有数据库

2. grant 作用在单个数据库上:

grant select on testdb.* to dba@localhost; — dba 可以查询 testdb 中的表。

3. grant 作用在单个数据表上:

grant select, insert, update, delete on testdb.orders to dba@localhost;

4. grant 作用在表中的列上:

grant select(id, se, rank) on testdb.apache_log to dba@localhost;

5. grant 作用在存储过程、函数上:

grant execute on procedure testdb.pr_add to ‘dba’@'localhost’
grant execute on function testdb.fn_add to ‘dba’@'localhost’

六、查看 MySQL 用户权限

查看当前用户(自己)权限:

show grants;

查看其他 MySQL 用户权限:

show grants for dba@localhost;

七、撤销已经赋予给 MySQL 用户权限的权限。

revoke 跟 grant 的语法差不多,只需要把关键字 “to” 换成 “from” 即可:

grant all on *.* to   dba@localhost;
revoke all on *.* from dba@localhost;

八、MySQL grant、revoke 用户权限注意事项

1. grant, revoke 用户权限后,该用户只有重新连接 MySQL 数据库,权限才能生效。

2. 如果想让授权的用户,也可以将这些权限 grant 给其他用户,需要选项 “grant option“

grant select on testdb.* to dba@localhost with grant option;

这个特性一般用不到。实际中,数据库权限最好由 DBA 来统一管理。

Category: Post
You can follow any responses to this entry via RSS.
Comments are currently closed, but you can trackback from your own site.

=========================================================================


1.创建用户并授权

grant语句的语法:

    grant privileges (columns) on what to user identified by "password" with grant option 
要使用该句型,需确定字段有:

privileges 权限指定符权限允许的操作
    alter 修改表和索引
    create 创建数据库和表
    delete 删除表中已有的记录
    drop 抛弃(删除)数据库和表
    index 创建或抛弃索引
    insert 向表中插入新行
    reference 未用
    select 检索表中的记录
    update 修改现存表记录
    file 读或写服务器上的文件
    process 查看服务器中执行的线程信息或杀死线程
    reload 重载授权表或清空日志、主机缓存或表缓存。
    shutdown 关闭服务器
    all 所有;all privileges同义词
    usage 特殊的“无权限”权限

以上权限分三组:

     第一组:适用于数据库、表和列如:alter create delete drop index insert select update

     第二组:数管理权限 它们允许用户影响服务器的操作 需严格地授权 如:file process reload shut*

     第三组:权限特殊 all意味着“所有权限” uasge意味着无权限,即创建用户,但不授予权限

columns

  权限运用的列(可选)并且你只能设置列特定的权限。如果命令有多于一个列,应该用逗号分开它们。

what

  权限运用的级别。权限可以是全局,定数据库或特定表.

user

  权限授予的用户,由一个用户名和主机名组成,许两个同名用户从不同地方连接.缺省:mysql用户password

  赋予用户的口令(可选),如果你对用户没有指定identified by子句,该用户口令不变.

    用identified by时,口令字符串用改用口令的字面含义,grant将为你编码口令.

      注:set password使用password()函数
with grant option

    用户可以授予权限通过grant语句授权给其它用户(可选)

 

实例讲解:

    grant all on db_book.* to huaying@koowo.com identified by "yeelion" 只能在本地连接

    grant all on db_book.* to huaying@vpn.koowo.com identified by "yeeliong" 允许从此域连接

    grant all on db_book.* to huaying@% identified by "yeelion" 允许从任何主机连接

      注:"%"字符起通配符作用,与like模式匹配的含义相同。

    grant all on db_book.* to huaying@%.koowo.com identified by "yeelion";

      允许huaying从koowo.com域的任何主机连接

    grant all on db_book.* to huaying@192.168.1.189 identified by "yeelion"

    grant all on db_book.* to huaying@192.168.1.% identified by "yeelion"

    grant all on db_book.* to huaying@192.168.1.0/17 identified by "yeelion"

      允许从单IP 段IP或一子网IP登陆

      注:有时 用户@IP 需用引号 如"huaying@192.168.1.0/17"

    grant all on *.* to huaying@localhost identified by "yeelion" with grant option

      添加超级用户huaying 可在本地登陆做任何操作.

    grant reload on *.* to huaying@localhost identified by "yeelion" 只赋予reload权限

    grant all on db_book to huaying@koowo.com indetified by "yeelion" 所有权限

    grant select on db_book to huaying@% indetified by "yeelion" 只读权限

    grant select,insert,delete,update on db_book to huaying@koowo.com indetified by "yeelion"

      只有select,insert,delete,update的权限

    grant select on db_book.storybook to huaying@localhost indetified by "yeelion" 只对表

    grant update (name) on db_book.storybook to huaying@localhost 只对表的name列 密码不变

    grant update (id,name,author) on db_book.storybook to huaying@localhost 只对表的多列

    grant all on book.* to ""@koowo.com 允许koowo.com域中的所有用户使用库book

 

    grant all on book.* to huaying@%.koowo.com indetified by "yeelion" with grant option

      允许huaying对库book所有表的管理员授权.

 

2.撤权并删除用户

revoke的语法类似于grant语句

    to用from取代,没有indetifed by和with grant option子句. 如下:

    revoke privileges (columns) on what from user

    user:必须匹配原来grant语句的你想撤权的用户的user部分。

    privileges:不需匹配,可以用grant语句授权,然后用revoke语句只撤销部分权限。

    revoke语句只删权限不删用户,撤销了所有权限后user表中用户记录保留,用户仍然可以连接服务器.

    要完全删除一个用户必须用一条delete语句明确从user表中删除用户记录:

      delete from user where user="huaying"

      flush privileges; 重载授权表

        注:使用grant和revoke语句时,表自动重载,而你直接修改授权表时不是.

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 序列化
Python 序列化

本专题整合了python序列化、反序列化相关内容,阅读专题下面的文章了解更多详细内容。

12

2026.02.02

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

200

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

98

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

15

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

16

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

9

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

62

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

56

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

28

2026.01.31

热门下载

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

精品课程

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

共48课时 | 8.4万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

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

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