【java.sql.SQLException: Access denied for user ‘root‘@‘localhost‘ (using password: YES)】异常问题及解决

【java.sql.SQLException: Access denied for user ‘root’@‘localhost’ (using password: YES)】学习SpringCloud过程中遇到的问题及解决

前言

自学最新版本的 SpringCloud alibaba,将以前的知识进行巩固,并了解一下新版本的巨大更新。在数据库方面没有牵扯Mybatis,而是用的原始的Hibernat,在学习过程中,在码完练习代码以后,运行代码的时候,出现了这样一个【java.sql.SQLException: Access denied for user ‘root’@‘localhost’ (using password: YES)】异常;

本人版本:

  • MySQL:8.0.26
  • Maven:3.9.1
  • SpringBoot:3.1.2
  • JDK:17

异常图示

【java.sql.SQLException: Access denied for user ‘root’@‘localhost’ (using password: YES)】异常

这个异常的意思是:拒绝用户“root”@“localhost”的访问(使用密码:YES),也就是说密码不正确(但是我的密码并没有什么问题)。

原因分析及改正过程

上网了解后发现可能出现的情况:

  • 第一种:可能用户名和密码不匹配,或者是password中多打了空格或者打错字符之类的;

    在编写这种类似于xml、properties、yml文件的时候,因为代码格式的问题,难免会出多打、少打、甚至于打错的问题,所以首先要排除的就是这种情况。

  • 第二种:用户的权限不够,给他添加权限。

    排查过程:

    1、首先,我在mysql的bin目录下打开命令行:mysql -u root -p 输入密码,是可以正常连接的;

    2、第二,我将曾经编写的 springboot 和 mybatis 的练习项目运行,是没有出现类似问题的;

    所以不是这个问题。

    (因为用户的权限不够的问题我没有遇到,但在其他博主那里浏览过,解决方案可以查到)

  • 第三种(也就是我的情况)

    首先我们需要对 yml 文件有一定的了解。

    YML文件,也叫做YAML,是一种人类可读的数据序列化格式,用于在不同的编程语言之间进行数据交换。它的设计目标是易于阅读、编写和理解,并且可以与多种编程语言无缝集成。

    YAML文件使用缩进和特定的符号来表示数据结构,包括列表、映射、标量值等。YAML文件可以用于配置文件、数据序列化、API请求和响应等多种场景。在读取或解析YAML文件时,你可以使用相应的库或工具来将其转换为适合你所使用的编程语言的数据结构,以便进行进一步的处理和操作。

    回归到我们所遇到的问题,在 yaml 文件中对于数字的处理中,YAML解析器会自动将它们解析为相应的数字类型,而不需要额外的引号。如果需要将数字作为字符串处理,可以使用双引号将其括起来,YAML解析器此时会将其解析为字符串类型,而不是数字类型。

    在我们所遇到的这种情况下,我们的密码其实是字符串类型的内容,所以只需要将其用双引号括起来,这个问题就解决了。

    【补充】:yml 文件配置字符串,使用 @Value 注解注入。当配置的字符串是0开头的数字时,yml会把 0开头的数字当作8进制处理,注入时转化为十进制数;会报错【Failed to convert value of type ‘java.lang.String’ to required type ‘int’】,因是 yml 文件字符串配置不规范。

解决结果图示:

连接成功!

花了一个小时解决的问题,只是双引号,但也收获十足。

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES) 是一个常见的数据库连接错误,表示用户'root'在本地主机上使用了错误的密码进行连接。 解决这个问题的方法有以下几种: 1. 确保用户名和密码正确:首先,确保你使用的用户名和密码是正确的。检查你的数据库配置文件或者数据库管理工具中的用户名和密码是否与你尝试连接的数据库一致。 2. 检查数据库权限:如果用户名和密码是正确的,但仍然无法连接数据库,可能是因为该用户没有足够的权限访问数据库。请确保该用户具有正确的权限,包括连接数据库和执行所需的操作。 3. 检查数据库连接字符串:检查你的数据库连接字符串是否正确。确保连接字符串中的用户名、密码和数据库名称都是正确的。 4. 检查数据库服务器配置:如果以上方法都没有解决问题,可能是因为数据库服务器的配置有问题。请检查数据库服务器的配置文件,确保允许远程连接,并且没有其他限制。 5. 检查防火墙设置:有时候,防火墙设置可能会阻止数据库连接。请确保你的防火墙允许数据库连接。 6. 重置密码:如果你确信用户名和密码是正确的,但仍然无法连接数据库,可以尝试重置密码。使用数据库管理工具或者命令行工具重置密码,并更新你的应用程序中的连接信息。 这些方法应该能够帮助你解决java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HB0o0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值