MyBatis(自用)

myBatis是一个持久层框架,是一个半自动的orm(对象关系映射)框架。MyBatis的着力点,就是对象与SQL之间的映射关系。半自动是相对于Hibernate 这种提供了全面的数据库封装机制的全自动orm框架而言。ORM是一种规范,它描述了对象和数据库表之间的关系,实现ORM的规范,可以让对象数据和关系数据进行互相转换,解决了面向对象编程语言与底层关系数据的不协调,创建了对象数据与关系数据的桥梁。
映射的基本规则:
1、类和表相对应
2、类中的属性和表中的字段相对应
3、一个类可以对应多张表,一个表也可以对应多个类
4、数据库表中可以没有主键,但是对象当中必须要有主键
5、数据库表与表的关系映射称为对象与对象之间的关系
6、对象中的属性和数据库表中的字段可以不同,不同包括名称和个数。

myBatis连接数据库的方式与jdbc略有不同,jdbc每一次连接数据库都要打开一次连接,执行sql语句后,又要关闭一次连接。数据库连接的打开和关系及其影响操作数据库的效率,就这样出现了数据源的概念,数据源是一种提高数据库连接性能的常规优化手段,数据源负责维持一个数据库连接池,在获取数据源的时候,会创建多个数据库连接放入数据库连接池中,这样每次就不用去创建连接,而是从数据库连接池中拿,用完后,再放入数据库连接池中。典型的以空间换取时间的性能优化策略。

在这里插入图片描述
对象和表之间的关系。通过sql语句映射。myBatis就是对jdbc的一个封装。
优点:

myBatis的前身IBatis

数据库连接池:加载驱动、url、账号密码

映射文件:
1)传入参数类型通过parameterType属性指定
2)返回结果集类型通过resultType属性指定

映射器:
接口映射时,namespace必须和该接口所在的路径一样,实现的方法名字必须和接口的方法名字一样

映射文件:include 导入映射文件
sql标签,提取sql语句中语句段,通过include标签导入

resultMap 集合,
简单对象时使用resultType,一个对象里面包含其他对象的时候resultMap

自动映射,当对象属性名和列名相同时,会自动映射

动态sql:if、choose (when, otherwise)有点像switch 、where(不用自己写where 1=1)、foreach

缓存:
缓存机制就是将第一次从数据库查询的结果保存到缓存中,当下一次执行相同的dql语句时,就会直接在缓存中获取数据,不需要再从数据库中获取数据,这样大大提高了效率,提高效率是因为两点:1、缓存存在内存中,而数据库数据存在硬盘中,内存读取速度比硬盘读取速度快上很多倍,2、获得缓存不用连接数据库,因为连接数据库也是非常耗时的。
MyBatis中的缓存分为一级缓存,二级缓存和自定义缓存,一级缓存是一个session级别的缓存,当会话结束或者执行更新操作,缓存会被刷新。二级缓存是一个
一级缓存(sesseion级缓存):是一个会话的缓存,其存储作用域为 Session,当 会话关闭 、刷新或者执行更新操作之后,该Session中的所有 Cache 就将清空。二级缓存是一个Mapper级别的缓存,当前会话的关闭并不会并不会刷新二级缓存,二级缓存可能会出现脏数据,所有我基本没有开启过二级缓存,对二级缓存也不是很了解。
缓存注意事项:
1、只能在只有单表操作的表上使用缓存
2、查询操作大于更新、插入、和修改查找操作的情况下使用缓存。
3、避免使用二级缓存(特别是多表操作)

默认打开。使用 sesseionOne.clearCache手动清除缓存
二级缓存:可以被多个会话共享,并不会因为会话结束或者执行更新操作而被清除。

MyBatissql语句设置参数三种方式:使用0、1、2编号的方式,使用param1、param2的方式,使用取别名的方式。

MyBatis多表查询:子查询(便于sql语句的重用)、联表查询

代码重构(code refactioring):代码重构就是不改变软件系统外部行为的前提下,改善它的内部结构。
为什么要做代码重构:续软件生命、适应需求变更,将内部结构进行优化,减少维护成本
何时做代码重构:代码中存在大量重复代码、过多的类和过长的方法、过渡耦合、设计有缺陷,到时修改维护成本不断提升,甚至威胁着软件的生命周期。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值