1.1什么是Mybatis
- MyBatis 是一流的持久化框架
- 支持自定义 SQL、存储过程和高级映射
- MyBatis 消除了几乎所有的 JDBC 代码和手动设置参数和检索结果
- MyBatis 可以使用简单的 XML 或注解进行配置,并将原语、Map 接口和 Java POJO(Plain Old Java Objects)映射到数据库记录。
- MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis
- 2013年11月迁移到Github。
如何获得Mybatis
- maven仓库
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.2</version>
</dependency>
1.2 持久化
数据持久化
- 持久化就是将程序的数据在持久状态和瞬时状态转化的过程
- 内存:断电即使
- 数据库,io文件持久化
- 生活:冷藏、罐头
为什么需要持久化
- 有一些对象,不能丢掉
- 内存太贵
1.3 持久层
Dao层,Service层,Controller层·····
- 完成持久化工作的代码
- 层界限十分明显
1.4为啥需要Mybatis
-
帮助程序员将数据存入导数据库中
-
方便
-
传统的JDBC代码太复杂。简化、框架、自动化。
-
不用Mybatis也可以,更容易上手。技术没有高低之分
-
优点
-
- 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
- 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
- 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
- 提供映射标签,支持对象与数据库的orm字段关系映射
- 提供对象关系映射标签,支持对象关系组建维护
- 提供xml标签,支持编写动态sql。^ [2]1()
-
最重要的时:使用的人多!