MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
环境搭建
1. Java开发环境
首先,确保你的计算机上已经安装了Java开发环境。你可以通过访问Oracle官网下载并安装Java。
2. Maven
Maven 是一个项目管理工具,可以帮助我们更好地管理项目依赖。你可以通过访问Maven官网下载并安装Maven。
3. MyBatis
从MyBatis官网下载MyBatis的jar包,并将其添加到项目的依赖中。
创建项目
我们可以使用IDEA、Eclipse等开发工具创建一个Java项目。
1. 创建Maven项目
- 打开IDEA,点击“File” -> “New” -> “Project”。
- 选择“Maven”并点击“Next”。
- 输入项目信息,如项目名称、组织信息等。
- 在“Add Maven Project”界面,选择“Create from archetype”。
- 选择“maven-archetype-quickstart”,点击“Next”。
- 输入项目信息,点击“Finish”。
2. 添加依赖
在项目的pom.xml文件中添加以下依赖:
<dependencies>
<!-- MyBatis依赖 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!-- MySQL驱动依赖 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
</dependency>
<!-- Log4j日志依赖 -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.14.1</version>
</dependency>
</dependencies>
创建Mapper接口和XML文件
1. 创建Mapper接口
在项目的src目录下创建一个包,例如com.example.mapper,然后在该包下创建一个接口,例如UserMapper.java:
package com.example.mapper;
import com.example.entity.User;
import org.apache.ibatis.annotations.Select;
public interface UserMapper {
@Select("SELECT * FROM user WHERE id = #{id}")
User selectById(Integer id);
}
2. 创建XML文件
在项目的src目录下创建一个目录,例如com/example/mapper,然后在该目录下创建一个XML文件,例如UserMapper.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper">
<select id="selectById" resultType="com.example.entity.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
配置MyBatis
在项目的src目录下创建一个配置文件,例如mybatis-config.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/test?useSSL=false"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>
编写测试代码
在项目的src目录下创建一个包,例如com.example.service,然后在该包下创建一个类,例如UserServiceImpl.java:
package com.example.service;
import com.example.mapper.UserMapper;
import com.example.entity.User;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
public class UserServiceImpl implements UserService {
private SqlSessionFactory sqlSessionFactory;
public UserServiceImpl() {
try {
sqlSessionFactory = new SqlSessionFactoryBuilder().build(MyBatisUtil.class.getResourceAsStream("mybatis-config.xml"));
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public User selectById(Integer id) {
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper userMapper = session.getMapper(UserMapper.class);
return userMapper.selectById(id);
}
}
}
在项目的src目录下创建一个测试类,例如TestMyBatis.java:
package com.example;
import com.example.service.UserServiceImpl;
import com.example.entity.User;
public class TestMyBatis {
public static void main(String[] args) {
UserService userService = new UserServiceImpl();
User user = userService.selectById(1);
System.out.println(user);
}
}
运行程序
运行TestMyBatis类,你将看到控制台输出查询到的用户信息。
通过以上步骤,你已经成功地将MyBatis应用到Java项目中。MyBatis的强大之处在于其灵活性和易用性,你可以根据自己的需求进行配置和扩展。希望这篇文章能帮助你快速上手MyBatis,祝你在Java开发的道路上越走越远!
