引言
MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的工作。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects)映射成数据库中的记录。
本文将带你入门 MyBatis,通过手动调用 DAO(Data Access Object)来轻松掌握数据库操作精髓。
MyBatis 基础
1. MyBatis 简介
MyBatis 是一个半自动化的持久层框架,它将 SQL 映射和 Java 对象映射起来。使用 MyBatis,你可以将 SQL 语句与 Java 代码分离,使得代码更加清晰、易于维护。
2. MyBatis 核心组件
- SqlSessionFactory:用于创建 SqlSession 对象,SqlSession 是 MyBatis 的核心接口,用于执行 SQL 语句。
- SqlSession:用于执行 SQL 语句,管理事务,以及获取 Mapper 接口。
- Mapper 接口:定义了数据库操作的接口,MyBatis 会为接口生成实现类。
- Mapper XML:用于配置 SQL 语句和参数,以及映射结果集。
手动调用 DAO
1. 创建 Mapper 接口
首先,创建一个 Mapper 接口,定义数据库操作的接口方法。
public interface UserMapper {
User getUserById(Integer id);
void addUser(User user);
void updateUser(User user);
void deleteUser(Integer id);
}
2. 创建 Mapper XML
接下来,创建一个 Mapper XML 文件,配置 SQL 语句和参数。
<mapper namespace="com.example.mapper.UserMapper">
<select id="getUserById" resultType="com.example.entity.User">
SELECT * FROM user WHERE id = #{id}
</select>
<insert id="addUser">
INSERT INTO user (name, age) VALUES (#{name}, #{age})
</insert>
<update id="updateUser">
UPDATE user SET name = #{name}, age = #{age} WHERE id = #{id}
</update>
<delete id="deleteUser">
DELETE FROM user WHERE id = #{id}
</delete>
</mapper>
3. 创建 SqlSessionFactory
然后,创建一个 SqlSessionFactory 对象,用于创建 SqlSession 对象。
String resource = "org/mybatis/example/mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
4. 创建 SqlSession
创建一个 SqlSession 对象,用于执行 SQL 语句。
SqlSession sqlSession = sqlSessionFactory.openSession();
5. 调用 Mapper 接口方法
最后,调用 Mapper 接口方法执行数据库操作。
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(1);
System.out.println(user.getName());
sqlSession.commit();
sqlSession.close();
总结
通过以上步骤,你已经成功入门 MyBatis,并掌握了手动调用 DAO 进行数据库操作的方法。MyBatis 提供了强大的功能和灵活的配置方式,可以帮助你高效地完成数据库操作。
在实际项目中,你可以根据需求调整 Mapper 接口、Mapper XML 和配置文件,以适应不同的数据库操作场景。希望本文能帮助你更好地理解和应用 MyBatis。
