文章前言
本文是笔者通过自己学习过程中整理出来的笔记,如有漏洞和不足,请向我反馈。
笔者使用环境:
IntelliJ IDEA 2022.1.3(Ultimate Edition)(目前最新)
Amazon Corretto OpenJDK 11
Mnecraft Paper 1.16.5 Server
大家可以根据自己需求更改环境,版本差异不会太大
晚上正在为团队的Minecraft服务器部署新的插件,具体插件名称这里就不提了,依照团队部署规范,让插件对接了数据库,开启服务器后调试中遇到了问题。
插件报错内容如下图:
从图中可以看出,该报错信息是在SQL语句执行时发出的错误,具体语句是在插件某个类的createTable()方法中,也就是创建数据表方法,初步分析应该是SQL语句拼写错了,于是我就开始各种调试。
首先我先翻阅插件的源代码,找到了这个方法:
从源码可以分析出,这是通过反射来获取Bean中的属性名和属性类型,来拼接SQL语句,从源码上看建表方法是没有任何问题的,于是我又检查了MySQL数据库的General Log
日志
这个插件有4个Bean类需要创建数据库,而只有3个建表语句执行成功,那说明问题就出在第四个Bean上,但我当时没有仔细看那个Bean中的属性,疏忽了,既然MySQL的日志查不到错误的语句,那我干脆直接使用了JProfiler
工具,看看能不能远程调试出错误的SQL语句。
但结果不尽人意,还是只捕捉到了执行成功的SQL语句,错误的那条没有被捕捉到,怎么办呢,我只能再使用IDEA打断点远程Debug来试试了
首先先在项目中配置好远程JVM调试:(远程JVM的启动参数也不要忘记)
然后在源代码中,打断点,这里我直接在最后return的结果那打断点:
开启调试,重启服务器,随着插件的进一步加载,成功命中源代码,获取到最后返回的SQL语句:
格式化后:
create table if not exists sale
(
id int primary key not null auto_increment,
stack varchar(255),
meta varchar(255),
nbt varchar(255),
appear bigint,
owner varchar(255),
buyer varchar(255),
price varchar(31),
cost varchar(31),
heat int,
nickname varchar(255),
desc varchar(255),
classify varchar(255),
auction bit,
point bit,
admin bit
);
大家有没有发现什么问题?有个 desc
字段,建表时没有加上单引号,作者可能忽略了这个问题
在此之前我也没用仔细检查Bean中的各个属性名,没有想到这个问题,在这次的经历中丰富了经验,大家在开发时要记得注意一下保留关键字
的使用,不要因为一时的疏忽,Debug一晚上。
编码不规范: