最近在学习Mabatis的使用,在使用idea maven构建mabatis程序的时候遇到了以往在非maven构建的问题,总结如下,以备后查。
变更的MySQL JDBC 6.0驱动类名
MYSQL JDBC6.0+版本的驱动类全称限名改为了com.mysql.cj.jdbc.Driver,相比原来的名字,多了一个cj,并且需要在url中指明时区,否则会报错,例如url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC
使用maven构建导致未找到配置文件
我们构建普通的Java项目的时候需要的外部资源文件(比如一个txt文件)的起始目录是项目的根目录,而maven构建的项目却不同,以quickstart模板为例,其自动生成的源代码存放目录是src/main/java/selfPackagePath/xxx.java,而编译后所有的的class类会存放到target/classes/selfPackagePath/xxx.class,不包含任何非class文件,并且其中类的所用的当前位置是target/classes,也就是说,在原来src中存放的xml等其他配置文件并没有在编译后的包里,这会导致奇怪的文件找不到IOException。类所使用的当前路径可以通过Class.class.getClass().getResource("/").getPath()
查看。
解决的方法是在pom文件中添加例如下面一段配置信息
其作用是加载src/config中的以xml和properties为结尾资源文件到target/classes目录,加载src/main/java中的xml文件到target/classes,注意,加载的文件都是加载到以target/classes为起始的目录,如果加载的文件处于另一个子目录下,比如src/main/java/wenqi/xxx.xml,应用上面的配置,这个文件会被加载早target/classes/wenqi/xxx.xml,有点对齐头,加尾的意思。