MyBatis 笔记总结
1、MyBatis中的一些要点:
1.1 SqlMapConfig.xml:mybatis的全局配置文件,配置mybatis的运行环境等信息,包括mapper.xml文件
1.2 mapper.xml:sql映射文件
1.3 SqlSessionFactory:根据SqlMapConfig.xml构造
1.4 SqlSession:由SqlSessionFactory生成,操作数据库需要通过SqlSession进行
1.5 Executor:MyBatis底层定义的操作数据库的执行器接口
1.6 Mapped Statement:MyBatis底层封闭对象,包装了MyBatis配置信息及sql映射信息等,mapper.xml文件中的一个sql语句对应一个Mapped Statement对象,sql的id是其id。MappedStatememt对sql执行的输入输出参数进行定义,包括HashMap、基本类型、pojo、输入输出映射由Ececutor完成
2、MyBatis默认使用Log4j记录日志,使用时应在classpath中配置log4j.properties文件
3、MyBatis使用原始Dao和Mapper接口两种方法实现Dao,实现Dao时应该要注意SqlSession是线程不安全的,每个线程都应该有自己的实例,每个Session都应控制在一个请求或一个方法内,并在每次使用后要关闭Session(finally)
3.1 使用原始Dao开发方式,需要编写Dao接口和对应的实现类及映射文件,Dao实现类通过SqlSession及sql.xml文件中的sql id完成数据库读写
3.2 Mapper接口需要编写mapper接口和mapper文件,开发规范:
1)mapper.xml文件中的namespace和mapper接口类路径相同
2)mapper接口方法名和mapper.xml中定义的statement的id相同
3)mapper接口输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同
4)mapper接口输出参数类型和mapper.xml中定义的每个sql的resutType的类型相同
4、SqlMapConfig.xml配置文件常用配置内容:
1) properties:属性
利用properties标签可以引入外部文件如java属性文件,并在properties标签内定义其他内容
在properties元素属性加载顺序:
1)在properties体内定义的属性先被读取
2)propperties元素中的resource或url加载的属性
3)parameterType传递属性
加载时,后者会覆盖前者属性
2)settings:全局配置参数
MyBatis行为相关
3)typeAliases:类型别名
主要是自定义别名
4)environements:环境集合属性对象
environement:环境子属性对象
transactionManager:事务管理
dataSource:数据源
5) mappers:映射器
mappers配置几种方法
<mapper resource=""/>
<mapper url=""/>
<mapper class=""/>:要求mapper接口名称和mapper映射文件一样,在同一个目录下
<package name=""/>:注册指定包下所有mapper接口,要求mapper接口名称和mapper映射文件一样,在同一个目录下
5、mapper.xml文件
1)parameterType:输入类型,简单类型,pojo对象,hashmap
2)resultType:输出类型,简单类型,pojo对象,hashmap
3)resultMap:将查询结果映射为复杂类型的pojo
6、动态SQL
1)if:用于动态添加sql条件
2)where:和 if 配合使用自动处理第一个 if 中的 and
3)foreach:解析数组和List
4)sql:定义 sql 片段
7、一对一,一对多,多对多查询
resultMap 使用 association 和 collection 完成一对一和一对多高级映射
1)association 将关联查询信息映射到一个pojo对象中
2)collection 将关联查询信息映射到一个list集合中
8、延迟加载,在 association collection 中添加 select 内容指定查询Sql
9、查询缓存
MyBatis一级缓存的作用域是同一个SqlSession
MyBatis二级缓存的作用域是同一个namespace
10、和Spring整合时,sqlSessionFactory,dao要在spring中配置
MyBatis 笔记总结的更多相关文章
- Mybatis笔记二:接口式编程
目录 旧方法的弊端 接口式编程 接口式编程的好处 接口式编程的增删改查 旧方法的弊端 在Mybatis笔记一中,我们使用命名空间+id的方式实现了Mybatis的执行,不过这里的命名空间是我们随便写的 ...
- MyBatis笔记二:配置
MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...
- MyBatis笔记一:GettingStart
MyBatis笔记一:GettingStart 1.MyBatis优点 我们的工具和各种框架的作用就是为了我们操作数据库简洁,对于一些数据库的工具能帮我们少写一些处理异常等等的代码,但是他们并不是自动 ...
- 【MyBatis笔记】mapper文件的配置以及说明
<!doctype html>[MyBatis笔记]mapper文件的配置以及说明 figure:last-child { margin-bottom: 0.5rem; } #write ...
- mybatis笔记2 基础理论准备
之前发了一篇mybatis的crud入门笔记,算是入门了,为了让功力加深一级,来研究下mybatis的理论知识,哈哈,以后好拿来跟技术经理吹吹牛- 按照问题来吧!个人觉得有自主意识,带着自己的问题来研 ...
- mybatis笔记<二> 整合spring
mybatis与spring整合需要添加几个jar包,mybatis-spring, spring-context, spring-jdbc 1. spring ioc只要一个jar包就ok 2. 我 ...
- mybatis笔记<一> Demo
mybatis作为一个orm互联网公司基本都在用,今天写个笔记.记录一下mybatis使用 参考官网:http://www.mybatis.org/mybatis-3/getting-started. ...
- 【狂神说】JAVA Mybatis 笔记+源码
简介 自学的[狂神JAVA]MyBatis GitHub源码: https://github.com/Donkequan/Mybatis-Study 分享自写源码和笔记 配置用的 jdk13.0.2 ...
- mybatis笔记3 一些原理的理解
1,mybatis流程跟踪,原理理解 基本思路: 从SqlSessionFactory的初始化出发,观察资源的准备和环境的准备,以及实现持久层的一些过程: 进入SqlSessionFactoryBea ...
- mybatis笔记1 基本的配置和操作
mybatis比较轻量,适合开发比较小型的或者业务比较复杂的系统: 相对于hibernate来说可以灵活的写sql,更灵活的处理遇到的业务逻辑: 可以说hibernate是pojo实体对db的orm映 ...
随机推荐
- 201521123018 《Java程序设计》第11周学习总结
1. 本章学习总结 你对于本章知识的学习总结 2. 书面作业 一.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) 1.1 除了使用synchronized修饰方法实现互斥同步访问, ...
- html css 前端基础 学习方法及经验分享
前言: 入园第一天,想分享一点儿前端基础html css 的学习方法和一些经验给热爱前端,但是不知道从哪儿开始,依旧有些迷茫的新手朋友们.当然,适合每个人的学习方式不同,以下所讲的仅供参考. 一.关于 ...
- javascript面向对象编程笔记
对象:一切事物皆是对象.对象是一个整体,对外提供一些操作.比如说一个收音机是一个对象,我们不需要知道它的内部结构是什么,只需要会使用外部的按钮就可以使用收音机. 面向对象:面向对象语言的标志是他们都有 ...
- Spring第一篇【介绍Spring、引入Spring、Spring六大模块】
前言 前面已经学习了Struts2和Hibernate框架了.接下来学习的是Spring框架-本博文主要是引入Spring框架- Spring介绍 Spring诞生: 创建Spring的目的就是用来替 ...
- win10- *.msi 软件的安装,比如 SVN安装报2503,2502
1, 以管理员身份打开cmd , C:\Windows\System32\cmd.exe 2,输入: msiexec /package "安装文件的全路径" 3,按下回车. 例 ...
- TestNG操作详解
运行测试步骤方法有如下两种: 1. 直接在Eclipse运行testNG的测试用例, 在代码编辑区域鼠标右键, 选择Run as ->testNG Test 2. 在工程的根目录下, 建立tes ...
- java踩坑记
1.String 相等 稍微有点经验的程序员都会用equals比较而不是用 ==,但用equals就真的安全了吗,看下面的代码 user.getName().equals("xiaoming ...
- program 1 : python codes for login program(登录程序python代码)
#improt time module for count down puase time import time #set var for loop counting counter=1 #logi ...
- 移动端touch事件实现页面弹动--小插件
动手之前的打盹 说实话真的是好久没有更新博客了,最近一直赶项目,身心疲惫:最关键的是晚上还要回去上一波王者,实在是忙啊! 这周下来,清闲了些许,或许是因为要到国庆的缘故吧,大家都显得无精打采.俗话说的 ...
- Navicat for MySQL:快捷键整理
使用快捷键,提升工作效率! ctrl+q 打开查询窗口 ctrl+/ 注释sql语句 ctrl+shift +/ 解除注释 ctrl+r 运行查询窗口的sql语句 ctrl+shift+r 只运行选中 ...