mybatis学习二
Mybatis缓存
1:缓存的概念
当用户频繁查询某些固定 的数据时,第一次将这些数据从数据库查询出来,保存在缓存中(内存,高速磁盘)中
当下次用户再次查询这些数据时,不用再通过数据库查询,而是去缓存里面查询,减少网络连接和数据库查询带来的损耗
从而提高我们的查询效率,减少高并发访问带来的系统性能问题
2:Mybatis的缓存分为一级缓存和二级缓存
Mybatis的一级缓存是指在同一个sqlSession里面应用.
Mybatis的二级缓存可以跨越sqlSession,以mapper为单位创建,是系统级缓存.
Map<key,value>
3:一级缓存
当第一次发出sql请求的时候,Mybatis从数据库查询,并将结果存入一级缓存
当在同一个sqlSession里面发出同样的sql查询请求,Mytatis会直接从缓存中查找
如果没有,则从数据库中查找
注意:
a:Mybatis默认支持一级缓存,不需要另外的配置,但是在跟spring整合的时候,进行mapper代理开发
的方式时,mybatis的一级缓存是不存在的,因为代理模板每次调用完都会个关闭sqlSession
b:如果sqlSessioon里面出现commit操作,sqlSession中的缓存会被全部清空,避免出现脏读
c:一级缓存的存在形式(map)的数据结构
key:statementId+rowBounds+sql+sql参数
value:数据
4:二级缓存
* 如图所示:
a:Mybatis的二级缓存是mapper级别的,就是活二级缓存是以mapper配置文件的namespace为单位创建的
b:Mybatis的二级缓存需要在setting里面加入配置(默认是开启的)
<setting name = "cacheEnabled" value="true"/>
c:需要在mapper的映射文件中加入<cache/>标签才可以触发此映射文件开启二级缓存
d:在映射文件用到的查询对象必须序列化(实体类)
e:如果需要禁用某个statement的缓存,可以在这个statement里面单独设置 useCache="false"
* 二级缓存的相关配置
Mybatis与Spring的整合
1:引入spring和mybatis各自的jar包
2:引入spring与mybatis整合的包
mybatis-spring-1.2.4.jar
3:当有jar包冲突的时候,保留高版本的jar包
4:在spring的配置文件applicationContext.xml中
* 配置管理sqlSessionFactory
* 配置管理数据源
* 配置管理mapper对象
5:两种开发方式:
* 传统的接口和实现方式
* 基于mapper动态代理的方式
1:Mybatis的逆向工程
为了提高开发效率,Mybatis官方提供了一个逆向工程的组件,来根据数据库中的某个表生成对应
的实体类,mapper.xml,mapper.java
2:怎么做
* 需要一个jar包,一个逆向工程的配置文件,一小段java代码
* 新建一个java工程
* 更改逆向工程的配置文件
a 数据库信息
b mapper接口的文件位置
c mapper映射 的文件位置
b 加入需要逆向生成的表
* 运行主程序
总结:可以借鉴逆向工程生成代码的思想,如果字段过多,可以应用逆向生成的实体类以及增删改查的方法
其他的方法建议自己扩充编写
注意:要新建工程进行逆向工程,不要在开发的项目生成,会覆盖原来的工程
mybatis学习二的更多相关文章
- (原创)mybatis学习二,spring和mybatis的融合
mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...
- MyBatis学习(二)---数据表之间关联
想要了解MyBatis基础的朋友可以通过传送门: MyBatis学习(一)---配置文件,Mapper接口和动态SQL http://www.cnblogs.com/ghq120/p/8322302. ...
- MyBatis学习(二)
前言 昨天的博客简单的记录了MyBatis的起源.作用.配置以及一个简单的查询例子.写到一半的时候,觉得已经学会了MyBatis,可是全写完的时候才发现,如果多个参数查询,如何表的名字与类字段名不一样 ...
- MyBatis学习(二):与Spring整合(非注解方式配置MyBatis)
搭建SpringMVC的-->传送门<-- 一.环境搭建: 目录结构: 引用的JAR包: 如果是Maven搭建的话,pom.xml的配置如下: <?xml version=" ...
- mybatis学习二 全局配置文件常用配置
全局配置文件的详细解析可以参考mybatis的中文参考文档 1.全局配置文件中内容1.1 <transactionManager/> type 属性可取值1.1.1 JDBC,事务管理使用 ...
- mybatis 学习二 MyBatis简介与配置MyBatis+Spring+MySql
1.2.2建立MySql数据库 在C:\Program Files\MySQL\MySQL Server 5.7\bin下面: 首先连接MySQL: mysql -u root -p ...
- mybatis 学习二 conf xml 配置信息
xml映射配置文件 这个xml文件主要包括一下节点信息 * properties 属性 * settings 设置 * typeAliases 类型命名 ...
- MyBatis 学习二之简单练习巩固
1.新建一个maven项目并在pom.xml中添加依赖 2.项目架构 配置文件:SqlMapConfig.xml <?xml version="1.0" encoding ...
- java mybatis学习二
<select id="find1" parameterType="java.util.HashMap" resultType="com.xxx ...
随机推荐
- 一周总结:AutoEncoder、Inception 、模型搭建及下周计划
一周总结:AutoEncoder.Inception .模型搭建及下周计划 1.AutoEncoder: AutoEncoder: 自动编码器就是一种尽可能复现输入信号的神经网络:自动编码器必须捕 ...
- JAVA入门——Generic/泛型
在台科大的第二次JAVA作业,老师课上讲的内容是泛型. 泛型(generic),泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数.这种参数类型可以 ...
- oracle数据库修改连接数
最近在用weblogic部署项目,同时用的是oracle数据库,然后今天遇到一个问题:多个用户连接数据库连接不成功,有时提示被锁住,经检查发现一方面weblogic控制台中数据源的连接池配置没有配置足 ...
- Beta冲刺NO.6
Beta冲刺 第六天 1. 昨天的困难 1.对于设计模式的应用不熟悉,所以在应用上出现了很大的困难. 2.SSH中数据库的管理是用HQL语句实现的,所以在多表查询时出现了很大的问题. 3.页面结构太凌 ...
- alpha-咸鱼冲刺day7
一,合照 emmmmm.自然还是没有的. 二,项目燃尽图 三,项目进展 正在写登陆+注册ing 注册搞出来了!!!!!!!!QAQ(喜极而泣!!!!.jpg) 四,问题困难 数据流程大概是搞定了.不过 ...
- Python 实现双端队列 Deque
操作 Deque() 创建一个空的双端队列 add_front(item) 从队头加入一个item元素 add_rear(item) 从队尾加入一个item元素 remove_front() 从队头删 ...
- *.db-journal 是什么(android sqlite )数据库删除缓存
sqlite的官方文档,发现该文件是sqlite的一个临时的日志文件,主要用于sqlite数据库的事务回滚操作了.在事务开始时产生,在事务操作完毕时自动删除,当程序发生崩溃或一些意外情况让程序非法结束 ...
- 5种做法实现table表格中的斜线表头效果
table表格,这个东西大家肯定都不陌生,代码中我们时常都能碰到,那么给table加一个斜线的表头有时是很有必要的,但是到底该怎么实现这种效果呢? 我总结了以下几种方法: 1.最最最简单的做法 直接去 ...
- jQuery 写的textarea输入字数限制
//先判断浏览器是不是万恶的IE var bind_name = 'input';//默认事件 if (navigator.userAgent.indexOf(" ...
- JAVA_SE基础——37.main方法的详解
主函数 大家都会写吧. 大家一直都不知道为何这样设计,这样设计有什么好处呢? 白话解释: main函数的修饰符是public: 公共的 为何不用private 等等的修饰符 而规定只用public呢? ...