Mybatis是一个半ORM框架(对象关系映射),专注于SQL语句,不用关心JDBC操作的其他流程,提高了对数据库的开发效率。
Hibemate是全ORM框架、基于JDBC封装的框架
(1)介绍Mybatis的基本情况:ORM
(2)原理:
系统启动的时候会加载解析全局配置文件和对应的映射文件,加载解析的相关信息存储在Configuration对象,Configuration对象会跟SqlSessionFactory对象绑定,当用户请求到来的时候,会从SqlSessionFactory对象中获取SqlSession。
SqlSessionFactory–>SqlSession
# 4、Mybatis中如何实现缓存的扩展?
# 5、Mybatis和Hibernate的区别?
#{}
和${}
#{}
(使用较多的一种方式) #{}
的本质是占位符赋值;#{}
是预编译处理,在Mybatis处理#{}的时候会替换为"?“,然后调用PrepareStatement的set方法来对”?"进行赋值。${}
${}
的本质是字符串拼接; ${}
是Mybatis处理的时候就会直接替换,会有SQL注入的风险。_
,而属性符合java的要求使用驼峰。此时可以在mybatis的核心配置文件中设置一个全局配置,可以自动的将下划线映射为驼峰;在使用insert标签的时候,设置标签属性useGeneratedKeys=true
和keyProperty=“id”
,获取到自动增长的主键。
insert into t_user values (null,#{username},#{password},#{age},#{gender},#{email})
处理CRUD操作的标签:
select
、delete
、update
、insert
sql
:SQL代码片段
cache
:开启缓存需要在映射文件中设置cache标签
cache-ref
:
resultMap
:自定义映射关系
properties
:引入properties配置文件,例如配置数据库的jdbc.properties
。
settings
:可以设置自动将下划线映射为驼峰、开启延迟加载、按需加载等。
typeAliases
:类型别名。
environments
:配置链接数据库的环境
mappers
:引入MyBatis的映射文件。
逻辑分页和物理分页两种
逻辑分页:
物理分页:
数据库中有10000条数据,会给服务器10000条数据,客户端需要5条数据去分页,服务器会给客户端10000条数据,然后分页。
我们通过拦截器来实现分页的,
select * from xxx —> select * from (select * from xxx) t limit 0.10
执行器是什么?
SimpleExector:简单的执行器。每次执行操作都会开启一个新的Statement对象,用完就会like关闭。
ReuseExector:复用的执行器。实现了对Statement对象的复用。
BatchExector:可执行批处理任务的执行器。
所有的执行器都必须是在SqlSession的生命周期之内。
DefaultSqlSession是线程不安全的。
## 14.1 DefaultSqlSession是什么?
我们在工作中都不会单独的使用DefaultSqlSession,而是整合了Spring框架来使用Mybatis。
不安全的原因
线程不安全的原因是因为多个线程操作同一个对象,而这个对象被定义为了一个成员变量。
解决的方案
就是把这个成员变量变成一个局部变量,让多个线程不能操作就可以了。
Spring整合Mybatis是如何来解决数据安全问题的
创建了一个SqlSessionTemplate模板对象,定义了数据库操作的相关的方法,本质上是通过代理对象获取了DefaultSqlSession对象来执行的,而且把DefaultSqlSession对象声明在了局部变量当中,从而解决了线程不安全的问题。
下一篇:车队试验的远程实时显示方案