文章目录
- 前言
- 一、Mybatis是什么?
- 二、持久化
- 三、持久层
- 四、为什么需要Mybatis
- 五、MyBatis的优点
- 六、代码演示
- 总结
MyBatis简介
一、Mybatis是什么?
MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
二、持久化
1.持久化是将程序数据在持久状态和瞬时状态间转换的机制
即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在数据库中,或者存储在磁盘文件中、XML数据文件中等等。
JDBC就是一种持久化机制。文件IO也是一种持久化机制。
在生活中 : 将鲜肉冷藏,吃的时候再解冻的方法也是。将水果做成罐头的方法也是。
2.为什么需要持久化服务呢?那是由于内存本身的缺陷引起的
存断电后数据会丢失,但有一些对象是无论如何都不能丢失的,比如银行账号等,遗憾的是,人们还无法保证内存永不掉电。
内存过于昂贵,与硬盘、光盘等外存相比,内存的价格要高2~3个数量级,而且维持成本也高,至少需要一直供电吧。所以即使对象不需要永久保存,也会因为内存的容量限制不能一直呆在内存中,需要持久化来缓存到外存
三、持久层
什么是持久层?
完成持久化工作的代码块 . ----> dao层
大多数情况下特别是企业级应用,数据持久化往往也就意味着将内存中的数据保存到磁盘上加以固化,而持久化的实现过程则大多通过各种关系数据库来完成。
四、为什么需要Mybatis
Mybatis就是帮助程序猿将数据存入数据库中 , 和从数据库中取数据 .
传统的jdbc操作 , 有很多重复代码块 .比如 : 数据取出时的封装 , 数据库的建立连接等等... , 通过框架可以减少重复代码,提高开发效率 .
MyBatis 是一个半自动化的ORM框架 (Object Relationship Mapping) -->对象关系映射
所有的事情,不用Mybatis依旧可以做到,只是用了它,所有实现会更加简单!技术没有高低之分,只有使用这个技术的人有高低之别
五、MyBatis的优点
简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件就可以了,易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
提供xml标签,支持编写动态sql。
最重要的一点,使用的人多!公司需要!
六、代码演示
思路流程:搭建环境-->导入Mybatis--->编写代码--->测试
1.搭建实验数据库
2.打开IDEA,创建一个maven项目
3. 导入依赖的jar包
4.创建一个实体类Book
5.编写mapper映射文件(编写SQL)
6.编写数据源properties文件
7.编写全局配置文件(主要是配置数据源信息)
8.编写dao类
9.测试
import com.yhb.qy145.seventh.dao.BookDao; import com.yhb.qy145.seventh.entity.Book_info; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.junit.Before; import org.junit.Test; import java.io.Reader; import java.util.List; public class BookTest { /** * @program:Mydati06 * * @description: * *@author: * *@create:2021-12-0119:00 **/ private SqlSession session; @Before public void Before()throws Exception{ Reader reader = Resources.getResourceAsReader("mybatis.xml"); SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader); session = sessionFactory.openSession(); } //id查询 @Test public void test01(){ BookDao bookDao = session.getMapper(BookDao.class); Book_info book_info = bookDao.selectById(1007); System.out.println(book_info); } //查询 @Test public void test02(){ BookDao bookDao =session.getMapper(BookDao.class); List<Book_info> list = bookDao.selectAll(); System.out.println(list); } //增加 @Test public void teat03(){ BookDao bookDao = session.getMapper(BookDao.class); Book_info b = new Book_info(); b.setName("三国演义"); b.setAuthor("施耐庵"); b.setPrice(35); b.setPub("人民出版社"); bookDao.insertBook(b); session.commit(); } //删除 @Test public void test04(){ BookDao bookDao = session.getMapper(BookDao.class); bookDao.deleteBook(1011); session.commit(); } //修改 @Test public void test05(){ BookDao bookDao = session.getMapper(BookDao.class); Book_info b = new Book_info(); b.setId(1001); b.setName("水浒传"); b.setAuthor("施耐庵"); b.setPrice(88); b.setPub("人民出版社"); bookDao.updateBook(b); session.commit(); }