【Java/MySQL】Unknown system variable 'language'
调试一简单JDBC连MySQL的程序,发现出现异常,导致连接无法成功,报错信息是:Unknown system variable 'language'
解决方案:在pom.xml里,将原有的版本降下来,我的就从5.1.36降低到了5.1.24
<!-- mysql --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.24</version> </dependency>
之后程序就运行正常了,代码如下:
package com.mq; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.text.MessageFormat; public class Test { private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; private static final String DB_URL = "jdbc:mysql://127.0.0.1:3306/test"; private static final String USER = "root"; private static final String PSWD = "hy"; public static void main(String[] args) { Connection conn = null; Statement stmt = null; try { Class.forName(JDBC_DRIVER).newInstance(); conn = DriverManager.getConnection(DB_URL, USER, PSWD); stmt = conn.createStatement(); String sql = "select id,name,age from testtb order by id limit 10"; ResultSet rs = stmt.executeQuery(sql); int index = 0; while (rs.next()) { index++; String id = rs.getString("id"); String name = rs.getString("name"); String age = rs.getString("age"); String raw = "#{0},{1},{2},{3},{4}"; Object[] arr = { index, id, name, age }; String outStr = MessageFormat.format(raw, arr); System.out.println(outStr); } } catch (Exception e) { System.out.print("DB/SQL ERROR:" + e.getMessage()); } finally { try { stmt.close(); conn.close(); } catch (SQLException e) { System.out.print("Can't close stmt/conn because of " + e.getMessage()); } } } }
执行结果:
#1,1,andy,20,{4}
#2,2,bill,30,{4}
数据库里情况:
mysql> select * from testtb; +----+------+------+ | id | name | age | +----+------+------+ | 1 | andy | 20 | | 2 | bill | 30 | +----+------+------+ 2 rows in set (0.00 sec)
END
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2015-08-12 【Canvas与艺术】旋转六边形八瓣花
2015-08-12 【Canvas与国旗】土耳其国旗