我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL8.x使用GRANT为用户赋权时报错的解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL8.x使用GRANT为用户赋权时报错的解决

MySQL8.x使用GRANT为用户赋权时报错

问题描述

在安装 MySQL 8.x 的过程中,往往需要为 MySQL 中的一些账户赋予远程访问的权限。

在 MySQL 5.x 的版本中的操作方式

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;

在 MySQL 8.x 中版本中按照以上操作

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IDENTIFIED BY '123456' WITH GRANT OPTION' at line 1

原因分析

通过官网文档的指引可以知道,新版本的 MySQL 8.x 版本已经将创建账户和赋权的方式分开导致以上的命令在 MySQL 8.x 上执行报语法错误。

解决方案

最终解决方案

# 创建账户
CREATE USER '用户名'@'访问主机' IDENTIFIED BY '密码';
# 为创建的账户赋权
GRANT '权限列表' ON '数据库' TO '用户名'@'访问主机';
GRANT ALL ON *.* TO 'root'@'%';
# 刷新
FLUSH PRIVILEGES;

mysql版本:'for the right syntax to use near 'identified by 'password' with grant option'

查询mysql具体版本

SELECT @@VERSION

问题分析:

mysql版本8.0.13,在给新用户授权时,发生了变化:

1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'identified by  'password' with grant option' at line 5, Time: 0.000000s

出错的语句:

grant all privileges on *.* to 'root'@'172.16.10.203' identified by 'password' with grant option

修正后的语句:分开三次执行

#创建账户
create user 'root'@'172.16.10.203' identified by 'password'
#赋予权限,with grant option这个选项表示该用户可以将自己拥有的权限授权给别人
grant all privileges on *.* to 'root'@'172.16.10.203' with grant option
#改密码&授权超用户,flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里
flush privileges;

原因分析:

此版的的mysql版本把将创建账户和赋予权限分开了。

创建账户::create user ‘用户名'@‘访问主机' identified by ‘密码';
赋予权限:grant 权限列表 on 数据库 to ‘用户名'@‘访问主机' ;
with grant option这个选项表示该用户可以将自己拥有的权限授权给别人

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL8.x使用GRANT为用户赋权时报错的解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL8.x使用GRANT为用户赋权时报错的解决

目录mysql8.x使用GRANT为用户赋权时报错问题描述原因分析解决方案mysql版本:for the right syntax to use near identified by password with grant option总结
2023-04-27

Android应用中扫描二维码时出现用户禁止权限报错如何解决

这期内容当中小编将会给大家带来有关Android应用中扫描二维码时出现用户禁止权限报错如何解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Android扫描二维码时出现用户禁止权限报错问题解决办法当我用
2023-05-31

oracle解锁用户时报错ORA-01109: database not open的解决办法

#复制ora文件 cd /usr/oracle/app/oracle/admin/orcl/pfile ls cp init.ora.313202010110 /usr/oracle/app/oracle/product/11.2.0/dbhome_1/dbs
oracle解锁用户时报错ORA-01109: database not open的解决办法
2015-04-07

关于使用MySQL修改用户名密码报错的解决方案

先声明:使用的 MySQL 版本是 8.32 一、关于报错 Operation ALTER USER failed for ‘用户名’@‘localhost’ 是执行了语句: alter user '用户名'@'localhost'
2023-08-30

解决linux下使用python打开terminal时报错的问题

这篇文章主要介绍了linux下使用python打开terminal时报错,本文通过两种场景分析给大家详细讲解,需要的朋友可以参考下
2023-03-14

Python 使用os.remove删除文件夹时报错的解决方法

os.remove不能用来删除文件夹,否则拒绝访问。 # -*- coding:utf-8 -*-import osif __name__ == "__main__": os.remove('D:\test') 运行结果:删除空目录: #
2022-06-04

如何解决v-if与v-for同时使用报错的问题

这篇文章主要介绍了如何解决v-if与v-for同时使用报错的问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在进行项目开发的时候因为在一个标签上同时使用了v-for和v-i
2023-06-29

使用@Autowired注解引入server服务层方法时报错的解决方法

这篇文章给大家介绍使用@Autowired注解引入server服务层方法时报错的解决方法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。@Autowired注解引入server服务层方法时报错contentTypeSer
2023-06-25

node.js使用npm 安装插件时提示install Error: ENOENT报错的解决方法

在使用npm install安装扩展插件时,系统提示“npm install Error: ENOENT, stat 'C:Users<用户名>AppDataRoamingnpm'”。 以前都是很顺利的安装过程,没出现这种情况。我这里的解决
2022-06-04

如何解决使用stream将list转map时key重复导致报错的问题

这篇文章将为大家详细讲解有关如何解决使用stream将list转map时key重复导致报错的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。要将List对象集合转为map集合,可以通过stream流的形
2023-06-15

使用U盘升级Win10系统时报错“0x8024044a”的解决办法是什么

今天就跟大家聊聊有关使用U盘升级Win10系统时报错“0x8024044a”的解决办法是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。伴随着win10功能不断的完善,越来越多的人
2023-06-28

编程热搜

目录