MyBatis简介
MyBatis是一款优秀的持久层框架,它消除了几乎所有的JDBC代码和手动设置参数以及获取结果集的工作。MyBatis可以让我们在构建应用程序时,更加关注SQL本身,而不是花时间在编写JDBC代码上。
MyBatis入门
1. 环境搭建
首先,我们需要搭建MyBatis的环境。以下是步骤:
- 下载MyBatis的jar包,并添加到项目的依赖中。
- 创建一个配置文件
mybatis-config.xml,在其中配置数据库连接、事务管理等。 - 创建一个Mapper接口,用于定义SQL映射。
2. MyBatis核心组件
MyBatis的核心组件包括:
- SqlSessionFactory:用于创建SqlSession。
- SqlSession:用于执行SQL语句、管理事务、获取Mapper接口实例。
- Mapper接口:定义SQL映射和操作数据库的方法。
- SqlSource:用于获取SQL语句。
- ResultMap:用于定义结果集映射。
3. 编写SQL映射
在Mapper接口中,我们可以编写SQL映射。以下是一个简单的例子:
<select id="selectById" resultType="com.example.User">
SELECT * FROM users WHERE id = #{id}
</select>
这个映射会查询users表,并根据id字段获取一条记录。
4. 执行SQL映射
通过Mapper接口,我们可以执行SQL映射:
User user = sqlSession.selectOne("com.example.UserMapper.selectById", 1);
这里,我们通过Mapper接口执行了SQL映射,并获取了查询结果。
MyBatis项目实战
1. 创建项目
创建一个Java项目,并添加MyBatis的依赖。
2. 配置数据库
在mybatis-config.xml中配置数据库连接信息:
<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/mydb"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
3. 编写Mapper接口
创建一个Mapper接口,用于定义SQL映射:
public interface UserMapper {
User selectById(int id);
}
4. 编写SQL映射文件
在项目目录下创建mapper目录,并在其中创建UserMapper.xml文件:
<mapper namespace="com.example.UserMapper">
<select id="selectById" resultType="com.example.User">
SELECT * FROM users WHERE id = #{id}
</select>
</mapper>
5. 创建SqlSessionFactory
在项目中创建一个SqlSessionFactory:
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
6. 获取SqlSession
通过SqlSessionFactory获取SqlSession:
SqlSession sqlSession = sqlSessionFactory.openSession();
7. 执行SQL映射
通过SqlSession执行SQL映射:
User user = sqlSession.selectOne("com.example.UserMapper.selectById", 1);
8. 关闭SqlSession
sqlSession.close();
总结
本文从MyBatis入门到项目实战进行了详细的介绍,希望能帮助您轻松掌握数据持久化。在实际开发中,您可以根据项目需求调整配置和映射,以适应不同的场景。
