本文共 5329 字,大约阅读时间需要 17 分钟。
在IntelliJ IDEA中创建一个新的Maven项目,确保项目名称和基准目录设置正确。完成后,项目的pom.xml文件会自动生成,包含了项目的基本配置和依赖管理。
在pom.xml文件中,添加必要的依赖坐标:
org.mybatis mybatis 3.4.5 mysql mysql-connector-java 8.0.16 log4j log4j 1.2.12 junit junit 4.10
有时候 IDEA 可能不会自动导入新添加的依赖,尤其是当项目已经存在时。解决方法:
Maven Projects → Reimport All Maven Projects。File → Settings → 在 Maven 标签下,调整相关设置。创建一个简单的User类,包含基本属性和相应的set、get方法,以及toString方法:
package com.hejie.domain;public class User { private Integer id; private String username; private String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "User{ id=" + id + ", username=" + username + ", password=" + password }"; }} 创建一个接口 IUserDao,定义一个findAll方法:
package com.hejie.dao;public interface IUserDao { List findAll();} 创建sqlMapConfig.xml文件,配置MyBatis环境:
创建IUserDao.xml映射文件:
创建log4j.properties文件,配置日志输出:
# 输出格式log4j.rootLogger.level=DEBUGlog4j.appender.console=Consolelog4j.console.outputEnabled=truelog4j.console.log throttle=false# 日志文件路径log4j.file=logs/app.log# 日志格式log4j.appender.file=Filelog4j.file.name=app.loglog4j.file.encoding=UTF-8log4j.file.append=truelog4j.file.maxBackupIndex=5log4j.file.keep日志=7
编写测试类 MybatisTest:
package com.hejie;import com.hejie.dao.IUserDao;import com.hejie.domain.User;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.InputStream;import java.util.List;public class MybatisTest { public static void main(String[] args) throws Exception { // 读取配置文件 InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml"); // 创建工厂 SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = builder.build(in); // 获取SqlSession SqlSession sqlSession = factory.openSession(); // 获取DAO代理对象 IUserDao iuDao = sqlSession.getMapper(IUserDao.class); // 执行查询 List users = iuDao.findAll(); for (User user : users) { System.out.println(user); } // 释放资源 sqlSession.close(); in.close(); }} 如果不想使用XML配置,可以使用注解方式:
IUserDao 接口上添加 @Select 注解,并在方法上指定SQL语句:package com.hejie.dao;import org.apache.ibatis.annotations.Select;public interface IUserDao { @Select("select * from user") List findAll();} SqlMapConfig.xml 中使用 class 属性指定DAO接口:创建一个测试类,使用Junit框架:
package com.hejie;import com.hejie.dao.IUserDao;import com.hejie.domain.User;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import org.junit.runner.RunWith;import org.mockito.Mock;import org.mockito.junit.MockitoJUnitRunner;import static org.junit.jupiter.api.Assertions.*;@RunWith(MockitoJUnitRunner.class)public class MybatisTest { @Mock private SqlSession sqlSession; @Mock private IUserDao iuDao; @Test public void testFindAll() throws Exception { // setup when(iuDao.findAll()).thenReturn(mockList()); // execution List users = iuDao.findAll(); assertEquals(mockList().size(), users.size()); // teardown verify(sqlSession).close(); verify(iuDao).findAll(); } private List mockList() { return List.of(new User(1, "hejie", "password")); }} 确保日志能够正确记录信息,添加必要的配置文件,并在代码中使用 Logger 类进行日志输出。
namespace 和接口名称一致。@Select 注解上的SQL语句与DAO方法名称匹配。通过以上步骤,可以顺利完成MyBatis的入门配置和入门案例的编写。如果在过程中遇到问题,可以通过检查配置文件的路径和命名是否正确来解决。
转载地址:http://nvewz.baihongyu.com/