MyBatis基础教程:官网翻译中文版

需积分: 10 0 下载量 47 浏览量 更新于2024-09-05 收藏 114KB MD 举报
"mybatis基础总结" MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使你更好地将注意力集中在你的应用程序上。 本文档是 MyBatis 基础知识的中文翻译,主要涵盖了如何入门搭建 MyBatis 框架,以及核心组件的使用方法。 ### 构建 SqlSessionFactory SqlSessionFactory 是 MyBatis 的核心组件,它是用来创建 SqlSession 对象的工厂。SqlSession 提供了执行 SQL 查询和操作数据库的方法。SqlSessionFactory 的创建通常基于全局配置文件(mybatis-config.xml)。 #### 入门搭建 1. 全局配置文件:这是 MyBatis 系统的核心配置,包含了环境配置、映射文件位置等信息。下面是一个示例配置文件: ```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="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource> </environment> </environments> <mappers> <mapper resource="org/mybatis/example/BlogMapper.xml"/> </mappers> </configuration> ``` 这里,`environments` 部分定义了数据库连接的环境,`transactionManager` 用于事务管理,`dataSource` 定义了数据源,`property` 节点则用于配置数据库连接的详细信息。 2. Sql 映射文件:每个 SQL 映射文件(如 BlogMapper.xml)定义了 SQL 语句及其关联的参数和结果映射。例如: ```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="org.mybatis.example.BlogMapper"> <select id="selectBlog" resultType="Blog"> SELECT * FROM blog WHERE id = #{id} </select> </mapper> ``` `namespace` 属性对应于 Java 接口的全限定名,`id` 是 SQL 语句的唯一标识,`resultType` 指定了查询结果的 Java 类型,`#{id}` 用于从传入的参数中取出 id 值。 ### 使用 MyBatis 在创建了 SqlSessionFactory 后,可以通过它来获取 SqlSession 对象,进而执行 SQL 语句。例如: ```java SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis-config.xml")); SqlSession session = sqlSessionFactory.openSession(); try { Blog blog = session.selectOne("org.mybatis.example.BlogMapper.selectBlog", 101); // ... } finally { session.close(); } ``` 这里,`selectOne` 方法执行了 SQL 映射文件中定义的查询,并返回了博客对象。 通过这种方式,MyBatis 将 SQL 与 Java 代码分离,实现了灵活的 SQL 动态生成,同时也提供了强大的结果映射功能,使得处理数据库操作变得更加简单。MyBatis 支持注解和 XML 两种方式定义映射,可以根据项目需求选择合适的映射方式。此外,MyBatis 还允许自定义拦截器,以实现事务控制、性能监控等多种扩展功能。