MyBatis使用技巧、总结、注意事项
1、mybatis的官方文档地址
2、其他技巧:
2.1 如何在代码中拼接 like %%
<![CDATA[ and strategy_name like CONCAT('%',CONCAT(#{query.strategyName,jdbcType=VARCHAR},'%')) ]]>
其他如果只需要一个%,酌情使用CONCAT
2.2 数据库比较时日期的错误操作
2.2.1 异常情况:
1、DAO中对属性赋值,为Date类型;
@Override
public List<DataStatistic> getSumarry(DataStatisticQuery query) {
List<String> tableSuffixList = Arrays.asList(VirtualOrderUtils.createStringArray());
Map<String, Object> map = Maps.newHashMap();
map.put("tabCode", query.getTabCode());
map.put("tableSuffixList", tableSuffixList);
map.put("orderTimeBegin", query.getOrderTimeBegin());
map.put("orderTimeEnd", query.getOrderTimeEnd());
return this.selectList(this.getNameSpace("getSumarry"), map);
}
2、保证数据库中数据一致。XML 文件中如下使用:
2.1、查不到数据
<sql id="WHERE_ORDER_TIME_BEGIN_AND_END">
<if test="orderTimeBegin != null">
<![CDATA[ and order_time >= #{orderTimeBegin,jdbcType=DATE}]]>
</if>
<if test="orderTimeEnd != null">
<![CDATA[ and order_time <= #{orderTimeEnd,jdbcType=DATE}]]>
</if>
</sql>
而实际上:数据库中该字段的类型是:【`order_time` datetime DEFAULT NULL COMMENT '下单时间',】
2.2、可以查到数据
<sql id="WHERE_ORDER_TIME_BEGIN_AND_END">
<if test="orderTimeBegin != null">
<![CDATA[ and order_time >= #{orderTimeBegin}]]>
</if>
<if test="orderTimeEnd != null">
<![CDATA[ and order_time <= #{orderTimeEnd}]]>
</if>
</sql>
上面SQL的区别在于:
- 查不到是因为在拼接SQL时,取DAO层的值时,在字段后面添加了
jdbcType=DATE。导致无法查到。暂时不知道原因是什么,但要注意避免这种使用方式。
2.2.2 为什么会在后面指定jdbcType,及真正的错误与那样?
- 因为使用一个插件自动生成SQL,里面都有这个东西,所以就直接用了。
最终错误原因:不是不能用jdbcType,而是我jdbcType映射的类型写错了。应用jdbcType=TIMESTAMP。
关于jdbcType的使用:
- DATE和DATETIME的区别。DATE表示一个日期,肯定是有问题的。

- 如果使用
jdbcType=DATETIME:报错:No enum constant org.apache.ibatis.type.JdbcType.DATETIME
原因是MyBatis不支持DATETIME类型。实际上,对于MySQL的DATETIME,MyBatis中应该使用jdbcType=TIMESTAMP。- MyBatis支持的类型:

- MyBatis支持的类型:
2.2.3 关于什么时候使用jdbcType?
查询官网时可以发现

其他情况,MyBatis大部分场景可以自动分析出来。实际上,myBatis没有说什么时候用什么时候不用,感觉都可以使用,不区分select或者insert等语句,的。
2.3 SQL和resultMap中字段对应关系异常分析
只有两种异常情况:
- SQL中有,ResultMap中没有;
- 或者SQL中没有,ResultMap中有。
如果都有或者都没有,那就不会出现异常。
2.3.1 SQL中有,ResultMap中没有:
即ResultMap中的值不会被赋予从数据库中查到的值,因为没法把这个字段的值赋给具体的对象属性。
所以实际会取对象中的默认值:基本类型取初始化值,对象类型取null。
2.3.2 SQL中没有,ResultMap中有
还是ResultMap中的值不会被赋予从数据库中查到的值,因此根本不查这个字段。
所以实际会取对象中的默认值:基本类型取初始化值,对象类型取null。
2.3.3 总结:
以上两种情况其实一致,都是取对象属性的默认初始化值。
MyBatis使用技巧、总结、注意事项的更多相关文章
- MySQL索引类型总结和使用技巧以及注意事项
索引是快速搜索的关键.MySQL索引的建立对于MySQL的高效运行是很重要的.下面介绍几种常见的MySQL索引类型 在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytable ...
- [MySQL]索引类型总结和使用技巧以及注意事项
一.普通索引 这是最基本的索引,它没有任何限制.它有以下几种创建方式: 1.创建索引 CREATE INDEX [indexName] ON [mytable] ([column][(length)] ...
- 【转】mysql索引使用技巧及注意事项
一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 在数据 ...
- 使用css时的一些技巧及注意事项
<!-- TITLE: 使用css时的一些技巧及注意事项 --> # CSS推荐书写顺序: 1. 位置属性(position, top, right, z-index, display, ...
- MySQL索引类型总结和使用技巧以及注意事项 (转)
在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytable表: 代码如下: CREATE TABLE mytable( ID INT NOT NULL, us ...
- JavaScript一些基础技巧和注意事项,你了解这些吗?
总结了一些JavaScript在开发编码中的使用技巧,如有不对,欢迎指正. 一.JavaScript在HTML和XHTML的使用 使用<script>元素有两种方式:直接在页面中嵌入Jav ...
- mysql索引使用技巧及注意事项
一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 在数据 ...
- 使用mysql索引技巧及注意事项
一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 在数据 ...
- 高并发秒杀系统--mybatis整合技巧
mybatis实现DAO接口编码技巧 1.XML文件通过namespace命名空间关联接口类 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD ...
随机推荐
- 为什么Object.prototype在Function的原型链上与Function.prototype在Object的原型链上都为true
关于javascript的原型链有一个问题我一直很疑惑:为什么 Function instanceof Object 与 Object instanceof Function都为true呢? Func ...
- CF788A Functions again dp
求一个最长子段和就完了,可以出T1? code: #include <bits/stdc++.h> #define N 100006 #define ll long long #defin ...
- Java集合总结(三):堆与优先级队列
堆 满二叉树:满二叉树是指,除了最后一层外,每个节点都有两个孩子,而最后一层都是叶子节点,都没有孩子. 完全二叉树:完全二叉树不要求最后一层是满的,但如果不满,则要求所有节点必须集中在最左边,从左到右 ...
- jumpserver官方手动安装
测试环境 CPU: 64位双核处理器 内存: 4G DDR3 数据库:mysql 版本大于等于 5.6 mariadb 版本大于等于 5.5.6 环境 系统: CentOS 7 IP: 192.168 ...
- Selenium处理授权框,登录框,握手框
在Web自动化中,常常遇到三种弹框: JavaScript警告框,如alert,confirm,prompt等,如下图: 处理方法为driver.switch_to.alert().dismiss() ...
- Beyond Compare4激活码(版本 4.2.8)
w4G-in5u3SH75RoB3VZIX8htiZgw4ELilwvPcHAIQWfwfXv5n0IHDp5hv 1BM3+H1XygMtiE0-JBgacjE9tz33sIh542EmsGs1yg ...
- VUE项目开发流程
前期准备 安装npm 安装webpack\vue-cli(2.9.6版本--版本不同可能会导致以下一些目录结构以及错误解决办法不符合实际情况) 创建项目 初始化创建项目,项目名称.项目描述.拥有者等等 ...
- PHP 之验证码类封装
一.效果图 二.类代码 <?php /** * Created by PhpStorm. * User: Yang * Date: 2019/8/13 * Time: 10:51 */ clas ...
- 6.4hadoop idea本地运行器测试
1.1 本地运行器进行本地测试 写一个MapReduce驱动程序,执行job,实现tool接口,所以可以通过hadoop的命令行去设置为本地运行模式.实现tool的run函数,在run函数中创建jo ...
- 走进JavaWeb技术世界2:JSP与Servlet的曾经与现在
转载自:码农翻身 转自: 刘欣 码农翻身 1周前 我是Servlet, 由于很多框架把我深深地隐藏了起来,我变得似乎无关紧要了,很多人也选择性的把我给遗忘了. 其实,我还活得好好的呢, 只不过是从前台 ...