怎么办这是Apifox里执行http://localhost:9002/goods/getByUserName?name=“张三“为什么我改了还是500?

{ "timestamp": "2025-10-02T11:27:53.384+0000", "status": 500, "error": "Internal Server Error", "message": "nested exception is org.apache.ibatis.exceptions.PersistenceException: \r\n### Error querying database. Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure\n\nThe last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.\r\n### The error may exist in file [D:\SUM\代码\demo251001\target\classes\mapper\UserMapper.xml]\r\n### The error may involve com.daqin.demo251001.mapper.UserMapper.getByUserName\r\n### The error occurred while executing a query\r\n### Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure\n\nThe last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.", "path": "/goods/getByUserName" }怎么办这是Apifox里执行http://localhost:9002/goods/getByUserName?

name="张三"为什么我改了还是500?

根据错误信息分析,这是一个数据库连接失败的问题,而不是之前的MyBatis映射问题。主要错误是:

```

Failed to obtain JDBC Connection; nested exception is com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

```

问题分析

这是一个典型的数据库连接通信失败错误,常见原因包括:

解决方案

  1. **检查数据库服务状态**
  • 确认MySQL数据库服务是否正在运行

  • 检查数据库是否可以通过其他工具(如Navicat、MySQL Workbench)正常连接

  1. **检查application.yml/application.properties配置**

```yaml

spring:

datasource:

url: jdbc:mysql://localhost:3306/your_database_name

username: your_username

password: your_password

driver-class-name: com.mysql.cj.jdbc.Driver

```

  1. **检查数据库连接参数**
  • 确认数据库地址(`localhost`)、端口(`3306`)是否正确

  • 确认数据库名称是否存在

  • 确认用户名和密码是否正确

  • 检查是否需要添加时区参数: `?serverTimezone=UTC`

  1. **检查网络连接**
  • 确认应用程序能够访问数据库服务器

  • 检查防火墙是否阻止了数据库端口

  1. **检查MySQL驱动依赖**

```xml

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

</dependency>

```

  1. **增加连接池配置**

```yaml

spring:

datasource:

hikari:

connection-timeout: 20000

maximum-pool-size: 10

minimum-idle: 5

```

建议先检查数据库服务和连接配置是否正确。

相关推荐
麦麦鸡腿堡几秒前
Java_类的加载
java·开发语言
JIngJaneIL9 分钟前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js
超级大只老咪14 分钟前
数组的正向存储VS反向存储(Java)
java·开发语言·python
毕设源码-赖学姐19 分钟前
【开题答辩全过程】以 基于JSP的物流信息网的设计与实现为例,包含答辩的问题和答案
java·开发语言
Honmaple19 分钟前
Spring AI 2.x 发布:全面拥抱 Java 21,Redis 史诗级增强
java·人工智能·spring
代码or搬砖1 小时前
Java集合-Set讲解
java·开发语言
渣娃-小晴晴1 小时前
java集合在并发环境下应用时的注意事项
java·后端
北极糊的狐1 小时前
若依系统报错net::ERR_CONNECTION_TIMED_OUT的原因
java·windows·sql·mybatis
FLGB2 小时前
maven漏洞检测报告
java·maven