idea使用maven构建mybatis程序遇到的几个问题

最近在学习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文件中添加例如下面一段配置信息

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<build>
<resources>
<resource>
<directory>src/config</directory>
<includes>
<include>**/*.xml</include>
<include>**/*.properties</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>

其作用是加载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,有点对齐头,加尾的意思。

坚持原创技术分享,您的支持将鼓励我继续创作!