MyBatis简介及基本配置详解

发布时间: 2024-05-02 09:18:27 阅读量: 84 订阅数: 41
![MyBatis](https://img-blog.csdnimg.cn/20201213215226229.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODkzNDk3,size_16,color_FFFFFF,t_70) # 2.1 配置文件概述 MyBatis的配置文件是用来配置MyBatis框架的运行环境和行为的,它是一个XML格式的文件,通常命名为`mybatis-config.xml`。配置文件中包含了MyBatis框架运行所需的所有配置信息,包括数据库连接信息、映射文件配置、缓存配置、插件配置等。 ### 2.1.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="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/> <property name="username" value="root"/> <property name="password" value="password"/> </dataSource> </environment> </environments> <!-- 映射文件配置 --> <mappers> <mapper resource="com/example/mybatis/mapper/UserMapper.xml"/> </mappers> <!-- 缓存配置 --> <cacheEntries> <cacheEntry id="userCache" type="org.mybatis.caches.ehcache.EhcacheCache"/> </cacheEntries> <!-- 插件配置 --> <plugins> <plugin interceptor="com.example.mybatis.plugin.MyPlugin"/> </plugins> </configuration> ``` ### 2.1.2 配置文件中的主要元素 MyBatis配置文件中包含了以下主要元素: - **environments**:用于配置数据库连接信息,包括事务管理器和数据源。 - **mappers**:用于配置映射文件,映射文件定义了实体类与数据库表之间的映射关系。 - **cacheEntries**:用于配置缓存,缓存可以提高MyBatis的查询性能。 - **plugins**:用于配置插件,插件可以扩展MyBatis的功能。 # 2. MyBatis基本配置 ### 2.1 配置文件概述 #### 2.1.1 配置文件结构 MyBatis配置文件通常以`.xml`为后缀,其结构如下: ```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> <!-- 配置内容 --> </configuration> ``` #### 2.1.2 配置文件中的主要元素 配置文件中的主要元素包括: - `<environments>`:配置不同的数据库环境。 - `<databaseId>`:指定当前使用的数据库环境。 - `<properties>`:定义全局属性,可以在整个配置文件中使用。 - `<settings>`:配置MyBatis的全局设置,如缓存、日志等。 - `<typeAliases>`:定义别名,用于简化实体类名称。 - `<mappers>`:配置映射文件,用于映射实体类和数据库表。 ### 2.2 数据库连接配置 #### 2.2.1 数据库连接参数设置 在`<environments>`元素中,配置数据库连接参数: ```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/test" /> <property name="username" value="root" /> <property name="password" value="123456" /> </dataSource> </environment> </environments> ``` - `driver`:数据库驱动类名。 - `url`:数据库连接URL。 - `username`:数据库用户名。 - `password`:数据库密码。 #### 2.2.2 连接池配置 在`<dataSource>`元素中,配置连接池: ```xml <dataSource type="POOLED"> <property name="poolMaximumActiveConnections" value="10" /> <property name="poolMaximumIdleConnections" value="5" /> <property name="poolMaximumCheckoutTime" value="20000" /> </dataSource> ``` - `poolMaximumActiveConnections`:连接池中最大活动连接数。 - `poolMaximumIdleConnections`:连接池中最大空闲连接数。 - `poolMaximumCheckoutTime`:连接从池中取出后,最长可以被保持空闲的时间。 ### 2.3 映射文件配置 #### 2.3.1 映射文件结构 映射文件通常以`.xml`为后缀,其结构如下: ```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"> <!-- 映射内容 --> </mapper> ``` #### 2.3.2 映射文件中的主要元素 映射文件中的主要元素包括: - `<resultMap>`:定义结果集映射,用于将查询结果映射到实体类。 - `<sql>`:定义SQL语句片段,可以被其他元素引用。 - `<select>`:定义查询语句。 - `<insert>`:定义插入语句。 - `<update>`:定义更新语句。 - `<delete>`:定义删除语句。 # 3.1 实体类属性映射 实体类属性映射是将实体类的属性与数据库表中的字段进行关联,以便在进行数据操作时能够自动进行属性与字段之间的转换。 **3.1.1 属性与数据库字段的映射** 属性与数据库字段的映射可以通过在实体类属性上使用 `@Column` 注解来实现。`@Column` 注解包含以下主要属性: - `name`:指定映射的数据库字段名称。 - `columnDefinition`:指定数据库字段的定义,例如数据类型、长度等。 - `jdbcType`:指定映射的 JDBC 类型。 - `nullable`:指定该字段是否允许为 null。 ```java @Column(name = "user_id", columnDefinition = "INT NOT NULL") private Integer userId; ``` 这段代码将实体类的 `userId` 属性映射到数据库表中的 `user_id` 字段,该字段是一个非空整型。 **3.1.2 属性的类型映射** 除了直接映射属性与字段,还可以通过类型映射器来进行属性与字段之间的类型转换。类型映射器是一个接口,用于将 Java 类型映射到数据库类型。 ```java @Column(name = "birth_date", columnDefinition = "DATE") @Type(typeHandler = LocalDateTypeHandler.class) private LocalDate birthDate; ``` 这段代码将实体类的 `birthDate` 属性映射到数据库表中的 `birth_date` 字段,该字段是一个日期类型。通过指定 `@Type` 注解,将使用 `LocalDateTypeHandler` 类型映射器进行 Java `LocalDate` 类型与数据库 DATE 类型的转换。 ### 3.2 实体类与数据库表的关系映射 实体类与数据库表的关系映射是将实体类与数据库表之间的关系进行映射,以便在进行数据操作时能够自动进行实体类与表之间的转换。 **3.2.1 一对一关系映射** 一对一关系映射是指一个实体类与一个数据库表之间存在一对一的关系。在 MyBatis 中,可以通过 `@OneToOne` 注解来实现一对一关系映射。 ```java @OneToOne(mappedBy = "user") private UserDetail userDetail; ``` 这段代码将实体类的 `userDetail` 属性映射到 `User` 表中的 `user_detail` 表,该关系是一对一关系,其中 `user_detail` 表中的 `user_id` 字段是外键,指向 `User` 表中的 `id` 字段。 **3.2.2 一对多关系映射** 一对多关系映射是指一个实体类与一个数据库表之间存在一对多关系。在 MyBatis 中,可以通过 `@OneToMany` 注解来实现一对多关系映射。 ```java @OneToMany(mappedBy = "user") private List<Order> orders; ``` 这段代码将实体类的 `orders` 属性映射到 `Order` 表中的 `orders` 表,该关系是一对多关系,其中 `Order` 表中的 `user_id` 字段是外键,指向 `User` 表中的 `id` 字段。 # 4. MyBatis SQL映射 ### 4.1 SQL语句映射 #### 4.1.1 SQL语句的编写 在MyBatis中,SQL语句是通过XML映射文件中的`<sql>`标签来定义的。`<sql>`标签可以定义通用的SQL语句片段,这些片段可以被其他SQL语句引用和重用。 **示例:** ```xml <sql id="user_columns"> id, username, password, email </sql> ``` 这个`<sql>`标签定义了一个通用的SQL语句片段,用于获取用户表的列名。它可以通过`<include>`标签引用在其他SQL语句中。 #### 4.1.2 SQL语句的参数传递 MyBatis支持使用占位符或命名参数来传递SQL语句的参数。 **占位符:** ```xml <select id="get_user_by_id" parameterType="int"> SELECT * FROM users WHERE id = #{id} </select> ``` **命名参数:** ```xml <select id="get_user_by_name" parameterType="map"> SELECT * FROM users WHERE username = #{username} </select> ``` ### 4.2 结果集映射 #### 4.2.1 结果集映射的配置 MyBatis使用`<resultMap>`标签来配置结果集映射。`<resultMap>`标签定义了如何将查询结果映射到Java对象。 **示例:** ```xml <resultMap id="user_result_map" type="com.example.User"> <id column="id" property="id" /> <result column="username" property="username" /> <result column="password" property="password" /> <result column="email" property="email" /> </resultMap> ``` 这个`<resultMap>`标签将查询结果映射到`com.example.User`类。它定义了如何将`id`列映射到`id`属性,`username`列映射到`username`属性,以此类推。 #### 4.2.2 结果集映射的类型映射 MyBatis支持使用类型映射器来将数据库中的数据类型映射到Java对象中的数据类型。 **示例:** ```xml <resultMap id="user_result_map" type="com.example.User"> <id column="id" property="id" /> <result column="username" property="username" /> <result column="password" property="password" /> <result column="email" property="email" typeHandler="com.example.EmailTypeHandler" /> </resultMap> ``` 在这个示例中,`email`列使用自定义的`EmailTypeHandler`类型映射器来映射到`email`属性。类型映射器负责将数据库中的字符串值转换为Java对象中的`Email`对象。 ### 4.3 动态SQL MyBatis支持使用动态SQL来动态生成SQL语句。动态SQL允许根据运行时条件生成不同的SQL语句。 **示例:** ```xml <select id="get_users_by_criteria" parameterType="map"> SELECT * FROM users <where> <if test="username != null"> username = #{username} </if> <if test="email != null"> email = #{email} </if> </where> </select> ``` 这个动态SQL语句根据`username`和`email`参数生成不同的SQL语句。如果`username`参数不为null,则添加`username = #{username}`条件。如果`email`参数不为null,则添加`email = #{email}`条件。 # 5. MyBatis高级配置 ### 5.1 缓存配置 **5.1.1 一级缓存和二级缓存** MyBatis提供了一级缓存和二级缓存机制,用于提高数据库查询的性能。 * **一级缓存(Local Cache):** 存储在会话(Session)范围内的缓存,默认开启,每个会话维护一份自己的缓存,当会话关闭时,缓存也会被清除。 * **二级缓存(Global Cache):** 存储在全局范围内的缓存,默认关闭,需要手动开启,所有会话共享同一个二级缓存,数据在多个会话之间共享。 **5.1.2 缓存的配置和使用** **一级缓存配置:** ```xml <settings> <setting name="localCacheScope" value="STATEMENT"/> </settings> ``` * `localCacheScope`:指定一级缓存的范围,可选值有`STATEMENT`(默认)、`SESSION`、`NONE`。 **二级缓存配置:** ```xml <settings> <setting name="cacheEnabled" value="true"/> <setting name="useCache" value="true"/> <setting name="cacheTimeout" value="60000"/> </settings> ``` * `cacheEnabled`:启用或禁用二级缓存。 * `useCache`:指定是否使用二级缓存。 * `cacheTimeout`:设置缓存过期时间,单位为毫秒。 **缓存使用:** 使用`@CacheNamespace`注解开启实体类的二级缓存: ```java @CacheNamespace(implementation=MybatisCache.class) public class User { // ... } ``` **代码逻辑分析:** `@CacheNamespace`注解指定了实体类`User`使用`MybatisCache`作为二级缓存的实现类。 ### 5.2 插件配置 **5.2.1 插件的类型和功能** MyBatis插件是一种拦截器,可以拦截SQL语句的执行过程,在执行前或执行后进行额外的操作。常见的插件类型有: * **分页插件:** 对查询结果进行分页处理。 * **日志插件:** 记录SQL语句的执行日志。 * **性能插件:** 分析SQL语句的执行性能。 **5.2.2 插件的配置和使用** **插件配置:** ```xml <plugins> <plugin interceptor="com.example.MybatisPlugin"/> </plugins> ``` * `interceptor`:指定插件的实现类。 **插件使用:** 插件会在SQL语句执行前或执行后被调用,具体执行时机由插件的实现决定。插件可以获取到SQL语句、参数等信息,并进行相应的操作。 **代码逻辑分析:** ```java public class MybatisPlugin implements Interceptor { @Override public Object intercept(Invocation invocation) throws Throwable { // 在SQL语句执行前执行 // ... // 执行SQL语句 Object result = invocation.proceed(); // 在SQL语句执行后执行 // ... return result; } } ``` **代码逻辑分析:** `MybatisPlugin`实现了`Interceptor`接口,重写了`intercept`方法。在SQL语句执行前,`intercept`方法会在`proceed`方法之前执行;在SQL语句执行后,`intercept`方法会在`proceed`方法之后执行。 # 6. MyBatis实践应用 ### 6.1 MyBatis在Web开发中的应用 #### 6.1.1 整合MyBatis框架 在Web开发中,可以使用以下步骤将MyBatis框架整合到项目中: 1. **添加MyBatis依赖**:在项目构建文件中(如pom.xml)添加MyBatis依赖。 2. **配置MyBatis**:创建MyBatis配置文件(如mybatis-config.xml),配置数据库连接、映射文件等信息。 3. **创建映射文件**:为每个实体类创建映射文件(如UserMapper.xml),定义SQL语句和结果集映射。 4. **创建MyBatis会话工厂**:创建MyBatis会话工厂(SqlSessionFactory),用于创建会话(SqlSession)。 5. **使用MyBatis**:通过会话对象执行SQL语句,查询或更新数据。 #### 6.1.2 编写MyBatis映射文件 MyBatis映射文件是XML文件,用于定义SQL语句和结果集映射。以下是一个示例映射文件: ```xml <mapper namespace="com.example.dao.UserMapper"> <select id="selectUserById" parameterType="int" resultType="com.example.entity.User"> SELECT * FROM users WHERE id = #{id} </select> <insert id="insertUser" parameterType="com.example.entity.User"> INSERT INTO users (name, email) VALUES (#{name}, #{email}) </insert> <update id="updateUser" parameterType="com.example.entity.User"> UPDATE users SET name = #{name}, email = #{email} WHERE id = #{id} </update> <delete id="deleteUser" parameterType="int"> DELETE FROM users WHERE id = #{id} </delete> </mapper> ``` ### 6.2 MyBatis在数据分析中的应用 #### 6.2.1 使用MyBatis进行数据查询 MyBatis可以方便地进行数据查询。以下是一个使用MyBatis查询数据的示例代码: ```java try (SqlSession session = sqlSessionFactory.openSession()) { List<User> users = session.selectList("com.example.dao.UserMapper.selectUserById", 1); for (User user : users) { System.out.println(user.getName()); } } ``` #### 6.2.2 使用MyBatis进行数据更新 MyBatis也可以用于更新数据。以下是一个使用MyBatis更新数据的示例代码: ```java try (SqlSession session = sqlSessionFactory.openSession()) { User user = new User(); user.setId(1); user.setName("John Doe"); user.setEmail("john.doe@example.com"); session.update("com.example.dao.UserMapper.updateUser", user); session.commit(); } ```
corwn 最低0.47元/天 解锁专栏
买1年送3月
点击查看下一篇
profit 百万级 高质量VIP文章无限畅学
profit 千万级 优质资源任意下载
profit C知道 免费提问 ( 生成式Al产品 )

相关推荐

专栏简介
MyBatis实战指南专栏是一份全面且实用的指南,涵盖了MyBatis框架的各个方面。它从MyBatis的简介和基本配置开始,逐步深入到高级主题,如映射配置文件优化、动态SQL语句拼接、结果集映射、缓存机制、插件开发、批量操作优化、锁机制、异常处理、日志配置、权限控制整合、Redis集成、分布式事务、全文检索整合、多环境配置管理和性能调优。通过深入的讲解、丰富的示例和最佳实践,本专栏旨在帮助开发人员充分利用MyBatis,构建高效、可扩展和可维护的数据库应用程序。
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )

最新推荐

ZYPLAYER影视源的API接口设计:构建高效数据服务端点实战

![ZYPLAYER影视源的API接口设计:构建高效数据服务端点实战](https://maxiaobang.com/wp-content/uploads/2020/06/Snipaste_2020-06-04_19-27-07-1024x482.png) # 摘要 本文详尽介绍了ZYPLAYER影视源API接口的设计、构建、实现、测试以及文档使用,并对其未来展望进行了探讨。首先,概述了API接口设计的理论基础,包括RESTful设计原则、版本控制策略和安全性设计。接着,着重于ZYPLAYER影视源数据模型的构建,涵盖了模型理论、数据结构设计和优化维护方法。第四章详细阐述了API接口的开发技

软件中的IEC62055-41实践:从协议到应用的完整指南

![软件中的IEC62055-41实践:从协议到应用的完整指南](https://opengraph.githubassets.com/4df54a8677458092aae8e8e35df251689e83bd35ed1bc561501056d0ea30c42e/TUM-AIS/IEC611313ANTLRParser) # 摘要 本文系统地介绍了IEC62055-41标准的重要性和理论基础,探讨了协议栈的实现技术、设备接口编程以及协议的测试和验证实践。通过分析能量计费系统、智能家居系统以及工业自动化等应用案例,详细阐述了IEC62055-41协议在软件中的集成和应用细节。文章还提出了有效

高效率电机控制实现之道:Infineon TLE9278-3BQX应用案例深度剖析

![高效率电机控制实现之道:Infineon TLE9278-3BQX应用案例深度剖析](https://lefrancoisjj.fr/BTS_ET/Lemoteurasynchrone/Le%20moteur%20asynchronehelpndoc/lib/NouvelElement99.png) # 摘要 本文旨在详细介绍Infineon TLE9278-3BQX芯片的概况、特点及其在电机控制领域的应用。首先概述了该芯片的基本概念和特点,然后深入探讨了电机控制的基础理论,并分析了Infineon TLE9278-3BQX的技术优势。随后,文章对芯片的硬件架构和性能参数进行了详细的解读

【变更管理黄金法则】:掌握系统需求确认书模板V1.1版的10大成功秘诀

![【变更管理黄金法则】:掌握系统需求确认书模板V1.1版的10大成功秘诀](https://qualityisland.pl/wp-content/uploads/2023/05/10-1024x576.png) # 摘要 变更管理的黄金法则在现代项目管理中扮演着至关重要的角色,而系统需求确认书是实现这一法则的核心工具。本文从系统需求确认书的重要性、黄金法则、实践应用以及未来进化方向四个方面进行深入探讨。文章首先阐明系统需求确认书的定义、作用以及在变更管理中的地位,然后探讨如何编写有效的需求确认书,并详细解析其结构和关键要素。接着,文章重点介绍了遵循变更管理最佳实践、创建和维护高质量需求确

【编程高手养成计划】:1000道难题回顾,技术提升与知识巩固指南

![【编程高手养成计划】:1000道难题回顾,技术提升与知识巩固指南](https://media.geeksforgeeks.org/wp-content/cdn-uploads/Dynamic-Programming-1-1024x512.png) # 摘要 编程高手养成计划旨在为软件开发人员提供全面提升编程技能的路径,涵盖从基础知识到系统设计与架构的各个方面。本文对编程基础知识进行了深入的回顾和深化,包括算法、数据结构、编程语言核心特性、设计模式以及代码重构技巧。在实际问题解决技巧方面,重点介绍了调试、性能优化、多线程、并发编程、异常处理以及日志记录。接着,文章探讨了系统设计与架构能力

HyperView二次开发进阶指南:深入理解API和脚本编写

![HyperView二次开发进阶指南:深入理解API和脚本编写](https://img-blog.csdnimg.cn/6e29286affb94acfb6308b1583f4da53.webp) # 摘要 本文旨在介绍和深入探讨HyperView的二次开发,为开发者提供从基础到高级的脚本编写和API使用的全面指南。文章首先介绍了HyperView API的基础知识,包括其作用、优势、结构分类及调用规范。随后,文章转向脚本编写,涵盖了脚本语言选择、环境配置、基本编写规则以及调试和错误处理技巧。接着,通过实战演练,详细讲解了如何开发简单的脚本,并利用API增强其功能,还讨论了复杂脚本的构建

算法实现与分析:多目标模糊优化模型的深度解读

![作物种植结构多目标模糊优化模型与方法 (2003年)](https://img-blog.csdnimg.cn/20200715165710206.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2NhdWNoeTcyMDM=,size_16,color_FFFFFF,t_70) # 摘要 本文全面介绍了多目标模糊优化模型的理论基础、算法设计、实现过程、案例分析以及应用展望。首先,我们回顾了模糊集合理论及多目标优化的基础知识,解释了

93K部署与运维:自动化与监控优化,技术大佬的运维宝典

![93K部署与运维:自动化与监控优化,技术大佬的运维宝典](https://www.sumologic.com/wp-content/uploads/blog-screenshot-big-1024x502.png) # 摘要 随着信息技术的迅速发展,93K部署与运维在现代数据中心管理中扮演着重要角色。本文旨在为读者提供自动化部署的理论与实践知识,涵盖自动化脚本编写、工具选择以及监控系统的设计与实施。同时,探讨性能优化策略,并分析新兴技术如云计算及DevOps在运维中的应用,展望未来运维技术的发展趋势。本文通过理论与案例分析相结合的方式,旨在为运维人员提供一个全面的参考,帮助他们更好地进行