mybatisReview_10-11

为什么需要

SQL和Java编码分开,功能边界清晰

是什么

持久层框架(dao)

怎么用

1、导入依赖pom.xml
	Mybatis核心org.mybatis、junit测试junit、MySQL驱动mysql
2、全局配置文件mybatis-config.xml
 	引入外部文件 properties resource
	开发环境environment default:
		具体环境environment id
		事务管理器transactionManage type="JDBC"
		数据源dataSource type="POOLED"
			property name value
		Mybatis映射文件mappers
			mapper resource
		驼峰式名命
			settings
				setting name="mapUndersoreToCamelCase "  value="true"
		延迟加载
			settings
				lazyLoadingEnabled true
				aggressiveLazyLoading false
		实体类别名
			typeAliases
				package name
3、xxxMapper.xml
		名命空间 mapper namespace
			select id resultType
4.jdbc.properties
5.对一关系xxxMapper.xml:association和JavaType
  对多关系:collection ofType
  分步: association/collection select

动态SQL

where
	if test
update
	set
		if test

两端是否包含某些字符trim
suffixOverrides 取消后缀 | 分隔
choose
when
otherwise
foreach collection item separator index
引用已经抽取的SQL片段
include refid

缓存

一级缓存:SqlSession级别
二级缓存:SqlSessionFactory级别
Mapper.xml中加入cache
缓存的本质是一个Map
都是由PerpetualCache实现,只是调用者不同

逆向工程

pom
	build
		plugins
			plugin
				org.mybatis.generator
MBG配置文件
	执行MBG插件
QBC拼装查询条件
	Ceriteria

注意的问题

Java实体类中,要使用包装类
XML只是在框架初始化时加载

Tip

框架=jar包(特定功能的固定解决方案)+配置文件(个性化定制)
工厂模式:创建对象时,过程基本固定,封装
Mapper相当于之前的Dao,但Mapper不需要提供实现类,而是去加载XML文件
一般是功能开发完成,再加外键约束检查是否有Bug

日志

debug(调试)<INFO(信息)<WARN(警告)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java程序世界的一员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值