mybatis使用要点(2019.5.19)
接口入参
- 只有一个参数,叫啥都没问题
- 有两个参数以上,需使用@Param,否则名字依次为0、1、2和param1、param2、param3
- 一般用#,防sql注入;偶尔用$,比如需要动态表名等
接口返回结果
- 有resultMap和resultType
- resultMap需要定义一个resultMap元素,然后在元素里面把下划线转为驼峰
- resultType一般对应一个实体类,又或者HashMap(不是map),要写类的全路径,这样就需要在select里把下划线转驼峰
- 但下划线转驼峰最好用mapUnderscoreToCamelCase=true配置
underscore是下划线,和underline一样,但计算机一般用underscore
mybatis缓存
- 分一级缓存和二级缓存
- 一级
- 一级缓存默认打开,在同一个sqlSession里生效
- 如果结合了spring,那就是在同一个事务里
- 如果不同sqlSession、不同的事务、没有事务、或者执行了insert/update/delete操作,则一级缓存起不了作用
- 二级
- 二级缓存全局开关默认打开,但同时需要每个mapper里配置打开,mapper里的开关默认关闭
- 二级缓存可以跨sqlSession,也就是在同一个sqlSessionFactory里生效
- 但只对同一个mapper生效,如果别的mapper insert了,希望这个mapper select出来是新数据,可以配置cache-ref=别的mapper
- 二级缓存是在sqlSession关闭时写入,如果关闭前会一直使用一级,不会使用二级
- 二级缓存也是写入主机的内存里,使用map实现
- 如果不想用默认的内存map,可选择第三方的ehcache、redis等,mybatis支持好几种
- echcache除了内存还可以使用磁盘,redis可以多个主机内存共享
- 二级缓存有四种回收策略,默认是LRU最近最少使用策略
- 适用场景注意
- 一级缓存一般没bug,但如果取出后set了属性,没保存到数据库,又select取,则与数据库不一致,可关闭一级缓存解决:flushCache=true
- 二级缓存一般用在只有查询操作、或者单表操作、脏读没什么关系等场景
动态SQL-foreach-字段名和字段值
- foreach一般collection网上都是list
- 其实可以map,这样就可以实现动态字段名
- 比如map.put("fieldName", "fieldValue")
- 然后接口入参里map前加@Param mapName
- 然后动态sql里collection="mapName",就可以用了,动态拼接where 字段名=字段值
- 多个字段分隔符用" and "
2019.5.19
mybatis使用要点(2019.5.19)的更多相关文章
- iBatis & myBatis & Hibernate 要点记录
iBatis & myBatis & Hibernate 要点记录 这三个是当前常用三大持久层框架,对其各自要点简要记录,并对其异同点进行简单比较. 1. iBatis iBatis主 ...
- 2019.3.18考试&2019.3.19考试&2019.3.21考试
2019.3.18 C O D E T1 树上直接贪心,环上for一遍贪心 哇说的简单,码了将近一下午终于码出来了 感觉自己码力/写题策略太糟糕了,先是搞了一个细节太多的写法最后不得不弃疗了,然后第二 ...
- mybatis审查要点
1.where条件遗漏情况 <select id="findActiveBlogLike" resultType="Blog"> SELECT * ...
- 『2019/3/19 USACO测试 反思与总结』
2019/3/8 USACO测试 这是第三次考试了,不过这一次没有上一次考得好,也算是比较失误的,有一道题思路对但是写挂了. 还是看一下试题安排: 题号 试题分组 考察算法 思维难度 代码难度 1 银 ...
- SpringBoot+mybatis:报错Fri Oct 19 14:29:24 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requiremen
报错:Fri Oct 19 14:29:24 CST 2018 WARN: Establishing SSL connection without server's identity verifica ...
- 2019年19道java经典面试题(附答案)
1.不可变对象 指对象一旦被创建状态不能再改变.任何修改都会创建一个新的对象,如 String.Integer及其它包装类. 2.能否创建一个包含可变对象的不可变对象? 可以.不要共享可变对象的引用就 ...
- 【转载】Spring Boot【快速入门】2019.05.19
原文出处:https://www.cnblogs.com/wmyskxz/p/9010832.html Spring Boot 概述 Build Anything with Spring Boot ...
- java 超详细面经整理(持续更新)2019.12.19
目录 Java SE 请你解释HashMap中为什么重写equals还要重写hashcode? 请你介绍一下map的分类和常见的情况 请你讲讲Java里面的final关键字是怎么用的? 请你谈谈关于S ...
- 【转载】Spring学习(1)——快速入门--2019.05.19
原文地址:https://www.cnblogs.com/wmyskxz/p/8820371.html 认识 Spring 框架 Spring 框架是 Java 应用最广的框架,它的成功来源于理念 ...
随机推荐
- 李洪强经典面试案例33-如何面试 iOS 工程师
如何面试 iOS 工程师 推荐序 私下和很多朋友交流过这个话题,大部分求职者认为,我能做基本的 iOS 开发工作,就达到公司的要求了,殊不知公司招聘员工,更希望的是这个人能够在关键时候能够发挥一般 ...
- TC SRM 583 DIV 2
做了俩,rating涨了80.第二个题是关于身份证的模拟题,写的时间比较长,但是我认真检查了... 第三个题是最短路,今天写了写,写的很繁琐,写的很多错. #include <cstring&g ...
- 小程序多级下拉菜单demo
小程序多级下拉菜单demo - CSDN博客 https://blog.csdn.net/github_39371177/article/details/80251211
- 20170221 SE03 打包请求
请求处理:SE03 只会有其中两三个功能,还需要学习. 请求打包,是传输请求时候常用的一种方法. 步骤如下: 注意点:1.打包请求一定仔细检查,不要遗漏 如果请求不多,分开传是更好 ...
- (linux)INIT_WORK和INIT_DELAYED_WORK详解
朋友,你相信,一只蝴蝶在北京拍拍翅膀,将使得纽约几个月后出现比狂风还厉害的龙卷风吗?看过那部经典的影片蝴蝶效应的朋友们一定会说,这不就是蝴蝶效应吗.没错.蝴蝶效应其实是混沌学理论中的一个概念.它是 ...
- POJ1759 Garland —— 二分
题目链接:http://poj.org/problem?id=1759 Garland Time Limit: 1000MS Memory Limit: 10000K Total Submissi ...
- 修改DEDE系统数据库表前缀
1,修改之前我们先备份下数据(哥们儿之前没有备份,我艹,害苦了),备份的操作过程是:网站后台------系统------数据库备份/还原-------然后按提交.默认保存的数据在data/backup ...
- express 中文文档
express() 创建一个express应用程序 var express = require('express'); var app = express(); app.get('/', functi ...
- NavigationView更改菜单icon和title颜色变化效果
NavigationView menu默认icon和title会随着菜单状态改变而改变,选择某个菜单后再次打开侧边菜单后会发现该菜单的icon和title会变成应用的主颜色,其他菜单项仍然为黑色. 如 ...
- 自定义UITabBarController
用的时候直接拷贝代码即可. 1.在AppDelegate设置跟控制器为:PQTabBarController #import "PQTabBarController.h" @int ...