浅谈Mybatis中的零散点

首先mybatis是对jdbc的封装之后的框架,它并不直接对接数据库。

缓存

mybatis有一级缓存二级缓存,一级缓存是sqlsession级别的,二级缓存是mapper(namespace级别的)
mybatis默认是一级缓存

# 和 $的区别

引用: mybatis 的强大特性之一,也是它优于其他 ORM 框架的一个重要原因。mybatis 在对 sql 语句进行预编译之前,会对 sql 进行动态解析,解析为一个 BoundSql 对象,也是在此处对动态 SQL 进行处理的,动态解析流程大致如下:
1、占位符的处理
2、动态sql的处理
3、参数类型校验

$仅仅是String的替换,而#是sql预编译语句参数标识符

resultMap

使用场景一:一般开发会定义与数据库对应model对象和返回前端vo对象,而处理方式有俩种:

  • 自己写业务代码将model处理成vo对象
  • 利用mybatis里面的resultMap过滤选取有用的字段直接返回对象

使用场景二
除此之外resultMap还可以进行高级复杂的映射,利用resultMap的内部元素可以进行高级映射,内部元素常用比如有(constructor、association、collections)

利用association可以表示嵌套的一对一的关系
利用collections可以表示嵌套的一对多的关系
利用俩个collections嵌套就能表示多对多的关系了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值