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