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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
搭建MyBatis环境可以分为以下几个步骤: 1. 安装Java开发环境 首先需要安装Java开发环境,可以从Oracle官网下载最新的JDK版本。 2. 安装Maven Maven是一个Java项目构建工具,可以从Maven官网下载最新的Maven版本。 3. 创建Maven项目 在命令行中使用Maven创建一个新的项目,可以使用以下命令: ``` mvn archetype:generate -DgroupId=com.example.mybatis -DartifactId=mybatis-demo -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false ``` 这个命令将创建一个名为“mybatis-demo”的Maven项目。 4. 添加MyBatis依赖 在项目的pom.xml文件中添加MyBatis的依赖,可以使用以下代码: ```xml <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.6</version> </dependency> ``` 5. 配置MyBatis 在项目中创建一个名为“mybatis-config.xml”的文件,并添加MyBatis的配置信息,例如: ```xml <configuration> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis_demo"/> <property name="username" value="root"/> <property name="password" value="123456"/> </dataSource> </environment> </environments> <mappers> <mapper resource="com/example/mybatis/mapper/UserMapper.xml"/> </mappers> </configuration> ``` 这个配置文件中包含了数据库连接信息和Mapper文件的位置。 6. 创建Mapper文件 在项目中创建一个名为“UserMapper.xml”的文件,定义SQL语句和对应的Java方法,例如: ```xml <mapper namespace="com.example.mybatis.mapper.UserMapper"> <select id="getUserById" resultType="User"> select * from user where id = #{id} </select> </mapper> ``` 7. 创建Java类 在项目中创建一个名为“User.java”的Java类,定义属性和对应的getter和setter方法,例如: ```java public class User { private int id; private String name; private String email; // getter and setter methods } ``` 8. 创建Mapper接口 在项目中创建一个名为“UserMapper.java”的接口,定义对应的Mapper方法,例如: ```java public interface UserMapper { User getUserById(int id); } ``` 9. 编写测试代码 在项目中创建一个名为“App.java”的Java类,编写测试代码,例如: ```java public class App { public static void main(String[] args) { SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis-config.xml")); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.getUserById(1); System.out.println(user.getName()); sqlSession.close(); } } ``` 这个测试代码将创建一个SqlSession实例,并通过Mapper接口调用getUserById方法查询数据库,并输出结果。 以上就是搭建MyBatis环境的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值