MySQL用户分配权限

本文介绍如何在Windows环境下使用Navicat for MySQL连接到Linux服务器上的MySQL数据库,并详细讲解了如何通过MySQL命令创建用户、分配不同级别的权限以及解决连接过程中的防火墙问题。

目的:在Windows下使用Navicat for MySQL连接Linux下的MySQL得到读表的权限

MySQL创建新用户分配权限

先在Mysql添加一个新的用户

mysql> insert into mysql.user(Host,User,Password) values(‘%’,'test’,password(‘123456’));

然后分配权限

mysql> grant 权限1,权限2,…权限n on 数据库名称.表名称 to 用户名@用户地址 identified by ‘连接口令’;
eg:test用户在任意主机登录拥有对testdb数据库中user表的所有权限。
mysql>grant all privileges on testdb.user to test@’%’ identified by ‘123456’;
eg:为test分权限,test用户在192.168.1.100上登录有对testdb数据库所有表有增改查的权限。
mysql>grant insert,update,select on testdb.* to test@192.168.1.100 by ‘123456’;

也可以不创建用户直接执行grant语句,系统自动增加,该用户并分配权限。

例:增加一个test用户,密码为123456,只能在192.168.1.** (表示ip范围,最后一位ip随意)上登录,
并对testdb数据库有查询,增加,修改和删除的权限。
mysql>grant select, insert, update, delete on testdb.* to test@’192.168.1.%’ identified by ‘123456’;

权限分配后需要刷新一下

mysql>flush privileges;

需要注意防火墙端口3306是否开放

查看端口状态
/etc/init.d/iptables ststus
修改iptables:
vi /etc/sysconfig/iptables
这里写图片描述
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT
加入时应注意它一定要在
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT 的上面
然后重启防火墙
service iptables restart
如果还不行就关闭防火墙试试(不建议正式服务器关闭)
service 方式:
开启: service iptables start
关闭: service iptables stop
iptables方式:
查看防火墙状态:
/etc/init.d/iptables status
暂时关闭防火墙:
/etc/init.d/iptables stop
重启iptables:
/etc/init.d/iptables restart

### 如何在 MySQL 中创建新用户分配权限 #### 创建新用户MySQL 中,可以通过 `CREATE USER` 命令来创建新的用户账户。以下是具体的语法: ```sql CREATE USER 'username'@'host' IDENTIFIED BY 'password'; ``` - `'username'`: 新用户的名称。 - `'host'`: 定义该用户可以从哪个主机连接到数据库。可以指定为单个 IP 地址、域名或者通配符 `%` 表示任何主机[^4]。 - `'password'`: 设置登录密码。 例如,如果希望创建一个名为 `lyy` 的用户,并仅允许其从本地访问,则执行如下命令: ```sql CREATE USER 'lyy'@'localhost' IDENTIFIED BY '123456'; ``` 而为了使此用户能够从任意远程地址访问数据库,应改为以下语句: ```sql CREATE USER 'lyy'@'%' IDENTIFIED BY '123456'; ``` #### 刷新权限表 每当修改了用户定义或权限配置之后,都需要运行 `FLUSH PRIVILEGES` 来重新加载这些更改至内存中以便立即生效。 ```sql FLUSH PRIVILEGES; ``` #### 分配权限 一旦创建好用户后,就可以利用 `GRANT` 语句赋予相应的权限。基本形式如下所示: ```sql GRANT privileges_type ON database_name.table_name TO 'username'@'host' [IDENTIFIED BY 'password']; ``` 这里有一些常见的例子展示不同类型的权限授予方式: - **给予某个特定数据库的所有权限** ```sql GRANT ALL PRIVILEGES ON testdb.* TO 'lyy'@'%'; ``` - **给予全局范围内的全部权限(谨慎使用)** ```sql GRANT ALL PRIVILEGES ON *.* TO 'lyy'@'%'; ``` 注意,在某些情况下可能还需要再次确认刷新特权以确保最新设定被应用上去了。 以上就是关于如何在MySQL里头建立新使用者帐号连同指派适当存取权能的相关指导说明[^1][^2][^3].
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值