传智播客mybatis课堂笔记1

preview
需积分: 0 0 下载量 160 浏览量 更新于2022-08-08 收藏 332KB DOCX 举报
【传智播客mybatis课堂笔记1】 在深入探讨MyBatis之前,让我们先回顾一下JDBC编程的一些问题。在传统的JDBC编程中,我们通常会遇到以下挑战: 1. **资源管理**:JDBC程序中,数据库连接的创建与关闭频繁进行,这会消耗大量系统资源,影响性能。为解决这个问题,可以引入数据库连接池,如C3P0、Apache DBCP或HikariCP等,它们能够复用已建立的连接,减少资源开销。 2. **SQL硬编码**:在JDBC代码中,SQL语句通常是直接写在Java代码里的,当SQL需要变动时,就需要修改Java代码,这不利于代码的维护。同时,SQL语句的编写和执行分离不够明确,使得代码可读性下降。 3. **参数设置**:使用PreparedStatement预编译SQL以设置参数,但参数位置的硬编码可能导致代码难以维护。当SQL的WHERE条件发生变化时,需要调整Java代码中的参数设置顺序。 4. **结果集解析**:遍历ResultSet时,通常需要直接操作列名,如果SQL查询的列发生变化,解析代码也需要相应调整。如果能将查询结果自动映射到对象(POJO)中,可以提高代码的可维护性。 MyBatis作为一款优秀的持久层框架,正是为了解决这些问题而设计的。MyBatis的核心理念是将SQL语句与Java代码解耦,让开发人员更专注于SQL本身,而不必关心底层的JDBC操作。以下是MyBatis的主要特性: 1. **配置灵活**:MyBatis通过XML或注解方式配置SQL语句,使得SQL与Java代码分离,易于维护和调整。SQL可以根据需求自由编写,不必担心Java代码的改动。 2. **参数映射**:MyBatis支持动态SQL,可以使用OGNL表达式来动态构造SQL,避免了预编译参数的位置硬编码问题。此外,它可以自动将Java对象的属性与SQL参数进行映射,减少了手动设置参数的麻烦。 3. **结果集映射**:MyBatis可以将查询结果自动映射到Java对象,无需手动解析ResultSet。通过ResultMap配置,可以指定字段与Java对象属性之间的映射关系,即使字段名改变,映射关系也可以轻松调整。 4. **缓存机制**:MyBatis内置了本地缓存和二级缓存,可以有效提升数据访问速度,降低数据库压力。缓存策略可以根据需求灵活配置。 5. **事务管理**:MyBatis支持手动和自动事务管理,可以方便地控制事务的边界,保证数据的一致性。 6. **插件扩展**:MyBatis允许用户自定义拦截器,实现SQL执行过程中的功能增强,如日志记录、性能分析等。 MyBatis通过提供SQL语句的独立配置、自动参数映射和结果集转换等功能,极大地简化了数据库操作,提高了代码的可读性和可维护性,是现代Java Web开发中不可或缺的工具之一。在实际项目中,结合Spring框架使用MyBatis,可以构建出更加健壮和高效的持久层架构。