访问mysql数据库报错:Error querying database. Cause:java.sql.SQLSyntaxErrorException:Table 'xxx' doesn't exist
分类:计算机 | 数据库 | MySQL | 综合 1095
更新:2022-11-17 20:03:17编辑
1 异常描述
最近在客户现场部署系统后,访问某个功能时发现操作失败了,后台报错“Error querying database. Cause:java.sql.SQLSyntaxErrorException:Table 'xxx' doesn't exist”,如图所示:
2 异常分析
从报错的字面意思来看应该是数据库中没有要查询的表,但是我在数据库里看了一下这个表是存在的,那就应该是其它原因了,最终排查了一圈发现原来数据库中的表名是小写的,而mybatis xml文件中sql查询语句中把表名写成大写的了,而在某些情况下mysql的表名是大小写敏感的,所以才会出现找不到表的错误。
3 异常解决
3.1 方法1——将mybatis xml文件中的表名大小写改成和数据库中的大小写一致
这种办法是最有效的,但是检查起来比较麻烦,如果系统里有很多表出现这种问题的话改起来会比较慢。
3.2 方法2——在myql配置文件my.cnf中配置数据表大小写不敏感
1、mysql版本低于8.0
可以在配置文件/etc/my.cnf中添加配置项:
lower_case_table_names=1
然后重启mysql生效
2、mysql8.0及以上版本 只能在初始化的时候设置lower-case-table-names参数, 无法通过修改my.cnf实现(在my.cnf中增加配置会报错)
具体设置步骤:https://blog.csdn.net/qq_41788609/article/details/108511403
说明
操作系统会对mybatis xml文件中sql的编写有影响
猿导航
阅读排行榜
- 1vue和el-table使用经验-如何刷新表格数据10880
- 2three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目9445
- 3Microsoft Visual C++ Redistributable是什么,有什么作用?7176
- 4mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)5751
- 5uni-app使用经验—vue页面和html页面如何互相调用接口并传参5436
- 6Spring学习经验—@ResponseBody注解的使用说明4844
- 7Intellij IDEA下的版本控制VCS的启用与关闭4782
- 8Druid异常解决经验—java.sql.SQLException url not set4459
- 9如何用批处理命令(bat脚本)启动和停止windows服务4228
- 10nuxt.js项目中如何添加和使用全局变量4096
- 11解决SpringBoot使用maven下载不了jar包的问题3451
- 12linux中解压tar.gz文件报错“gzip: stdin: invalid compressed data--format violated”3339
- 13nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数3205
- 14在Nuxt.js项目的head中引用外部js文件3040
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一3018