mysql数据库权限赋予

本文详细介绍了MySQL数据库中用户权限的管理,包括如何赋予select、insert、update、delete等基本权限,以及如何通过GRANT语句设置远程访问和超级权限。特别提到了在授权过程中遇到的问题,如用户在主机上访问数据库时出现ERROR 1045错误,解决方案是针对localhost单独进行权限设置。此外,还解释了权限列的上下文和各种数据库操作的对应权限。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先设置该用户只有show database权限

grant select,insert,update,delete on redmine1.* to jira@"%" identified by “jira”;

新增超级权限并允许远程访问:

GRANT ALL PRIVILEGES ON . TO ‘myuser’@‘192.168.1.3’ IDENTIFIED BY ‘mypassword’ WITH GRANT OPTION;

FLUSH PRIVILEGES;

mysql8.0:

grant all privileges on . to ‘root’@‘localhost’;

授权命令GRANT 语句的语法如下:
GRANT privileges (columns)
ON what
TO user IDENTIFIEDBY “password”
WITH GRANT OPTION
对用户授权
mysql>grant rights on database.* to user@host identified by “pass”;
例1:
增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。
grant select,insert,update,delete on . to test1@"%" Identified by “abc”;
ON 子句中*.* 说明符的意思是“所有数据库,所有的表”
例2:
增加一个用户test2密码为abc, 让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作。
grant select,insert,update,delete on mydb.* to test2@localhost identified by “abc”;
例子3
增加一个用户custom,他能从主机localhost、server.domain和whitehouse.gov连接。他只想要从 localhost存取bankaccount数据库,从whitehouse.gov存取expenses数据库和从所有3台主机存取customer 数据库。他想要从所有3台主机上使用口令stupid。

为了使用GRANT语句设置个用户的权限,运行这些命令:
shell> mysql --user=root mysql
mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
ON bankaccount.* TO custom@localhost IDENTIFIED BY ‘stupid’;
mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
ON expenses.* TO custom@whitehouse.gov IDENTIFIED BY ‘stupid’;
mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
ON customer.* TO custom@’%’ IDENTIFIED BY ‘stupid’;

权限信息用user、db、host、tables_priv和columns_priv表被存储在mysql数据库中(即在名为mysql的数据库中)。
权限 列 Context
select Select_priv 表
insert Insert_priv 表
update Update_priv 表
delete Delete_priv 表
index Index_priv 表
alter Alter_priv 表
create Create_priv 数据库、表或索引
drop Drop_priv 数据库或表
grant Grant_priv 数据库或表
references References_priv 数据库或表
reload Reload_priv 服务器管理
shutdown Shutdown_priv 服务器管理
process Process_priv 服务器管理
file File_priv 在服务器上的文件存取

1.select、insert、update和delete权限 允许你在一个数据库现有的表上实施操作,是基本权限
2.alter权限允许你使用ALTER TABLE
3.create和drop权限允许你创建新的数据库和表,或抛弃(删除)现存的数据库和表 如果你将mysql数据库的drop权限授予一个用户,该用户能抛弃存储了MySQL存取权限的数据库!
4.grant权限允许你把你自己拥有的那些权限授给其他的用户。
你不能明显地指定一个给定用户应该被拒绝存取。即,你不能明显地匹配一个用户并且然后拒绝连接。你不能指定一个用户有权创建立或抛弃一个数据库中的表,也不能创建或抛弃数据库本身。 可以同时列出许多被授予的单个权限。
例如,如果想让用户能读取和修改已有表的内容,但又不允许创建新表或删除表,可按如下授权:
GRANT SELECT,INSERT,DELETE,UPDATE ON samp_db.* TO ‘user’@’%’ IDENTIFIEDBY “pass”

以上是我从别的地方拷贝过来后稍作修改的文字,下面自己写一些需要注意的东西。

为什么使用了Grant all on db.* to user identified by "pass"后,在主机上访问数据库还会出现ERROR 1045 (28000): Access denied for user ‘user’@‘localhost’ (using password: YES) 的错误提示?

解答方法如下:运行命令 Grant all on db.* to ‘user’@‘localhost’ identified by “pass”

原因是:当不加@选项时,效果与加@’%‘是一样的,’%‘从名义上包括任何主机,(%必须加上引号,不然与@放在一起可能不会被辨认出。)不过有些时候(有些版本)’%'不包括localhost,要单独对@'localhost’进行赋值

原文:https://www.cnblogs.com/jifeng/archive/2011/03/06/1972183.html

### 安装 MySQL 并配置远程连接 #### 准备工作 为了确保安全性和功能性,在Ubuntu上安装MySQL并设置其支持远程访问,需遵循一系列特定的操作流程。 #### 安装 MySQL Server 通过终端执行命令来更新包列表以及安装最新版本的MySQL服务器: ```bash sudo apt update && sudo apt install mysql-server ``` 完成上述操作后,启动MySQL服务并且将其设置为开机自启[^1]。 #### 配置 MySQL 远程访问权限 编辑`/etc/mysql/mysql.conf.d/mysqld.cnf`文件中的绑定地址部分,将bind-address修改为0.0.0.0或者具体的IP地址以便接受来自任何地方的数据请求。这一步骤至关重要因为默认情况下MySQL仅监听本地回环接口上的连接尝试[^2]。 #### 创建具有远程访问权限的新用户 登录到MySQL控制台之后创建一个新的数据库账户赋予相应的权限给该账号用于从外部网络位置进行管理活动: ```sql CREATE USER 'newuser'@'%' IDENTIFIED BY 'password'; GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%'; FLUSH PRIVILEGES; ``` 以上SQL语句定义了一个名为`newuser`的新用户,并授予此用户全局范围内的全部特权;请注意替换实际使用的用户名和密码字符串。 #### 开放防火墙端口 为了让外界能够触及到运行于内部的服务程序,则需要开放必要的通信端口号,默认情况下MySQL使用的是3306号TCP端口。对于基于UFW(Uncomplicated Firewall)防护机制下的Linux发行版而言,可以利用如下指令开启指定端口: ```bash sudo ufw allow 3306/tcp ``` 最后重启MySQL服务使更改生效: ```bash sudo systemctl restart mysql.service ``` 此时已经完成了基本的MySQL远程接入准备工作,但是建议进一步加强安全性措施比如采用SSL加密传输通道等方法提高系统的整体防御能力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值