mybatis 常用
1、新增时获得主键
<insert ...>
<selectKey resultType="java.lang.Integer" keyProperty="id" order="AFTER">
SELECT LAST_INSERT_ID()
</selectKey>
INSERT INTO ...
</insert>
或
<insert id="insert" parameterType="com.test.User" keyProperty="id" useGeneratedKeys="true" >
INSERT INTO ...
</insert>
2、Boolean判断
<if test="isReturnReport !=null and isReturnReport.toString() == 'true'.toString()">
...
</if>
3、大于、小于符号转义
& &
" "
' '
大于号: > > 或 <![CDATA[ > ]]>
小于号: < < 或 <![CDATA[ < ]]>
eg.
AND DATE_FORMAT(create_date,'%Y-%m-%d') >= #{beginDate, jdbcType=VARCHAR}
AND DATE_FORMAT(create_date,'%Y-%m-%d') <![CDATA[ >= ]]> #{beginDate, jdbcType=VARCHAR}
4、参数为逗号隔开的字符串
FIND_IN_SET(field,param)函数:
AND FIND_IN_SET(user_id,#{_parameter})
_parameter:
获取传入的原参数值,不作预编译处理
5、模糊查询
AND settle_name LIKE CONCAT('%',#{settleName,jdbcType=VARCHAR},'%')
6、级联查询
一对多查询:
一中的xml:
<collection property="optionsList"
column="id"
ofType="com.hs.qmct.app.web.model.question.QuestionOptions"
select="com.hs.qmct.app.web.dao.question.QuestionOptionsMapper.selectByQuestionId">
</collection>
多中的dao:
List<QuestionOptions> selectByQuestionId(Integer questionId);
传递多个参数时:
一中的xml:
column= "{prop1=col1,prop2=col2}"
多中的xml:
<select parameterType="java.util.Map" ....>
select .... where val1=prop1 and val2=prop2
</select>
多对一查询:
一中的xml:
<association property="district"
column="receive_district_id"
javaType="com.hs.qmct.app.web.model.district.District"
select="com.hs.qmct.app.web.dao.district.DistrictMapper.selectByPrimaryKey">
</association>
另一个一中的dao:
District selectByPrimaryKey(Integer id);
7、传参占位符#{}和${}的区别
#{} 具有预编译效果,一般作为条件传参时使用,可防止sql注入
${} 不具有预编译效果,一般在排序中会用到,偶尔也会作为条件传参
eg1.
SELECT id from tables where id=#{id} 解析为:SELECT id from tables where id=?
SELECT id from tables where id='${id}' 解析为:SELECT id from tables where id=原参数值
eg2.
ORDER BY ${param} 此时param是一个列名
ORDER BY #{_parameter} 此时传入的参数有且仅为一个列名
8、批量新增使用forEach
int batchInsert(List<Event> records);
<!--批量新增事件-->
<insert id="batchInsert">
insert into
hserp_sys_event(id, event_name_parent, event_name,event_desc, class_path, interface_path,create_by, create_date)
values
<foreach item="item" index="index" collection="list" separator=",">
(#{item.id}, #{item.eventNameParent}, #{item.eventName},
#{item.eventDesc}, #{item.classPath}, #{item.interfacePath},
#{item.createBy}, sysdate())
</foreach>
on DUPLICATE key update last_update_date = sysdate()
</insert>
传参主要有一下3种情况:
1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
2. 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
3. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了
9、解决int类型返回报错
IFNULL(MAX(SORT),0)
10、一次执行多条sql
需要在xml中加入
<property name="url" value="jdbc:mysql://localhost:3306/how2java?characterEncoding=UTF-8&allowMultiQueries=true"/>
或在配置文件中加入
hikariConfig.security.jdbcUrl=jdbc:mysql://xx.xx.xx:3306/xxxxx?characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false&allowMultiQueries=true
mybatis 常用的更多相关文章
- Mybatis 常用注解
Mybatis常用注解对应的目标和标签如表所示: 注解 目标 对应的XML标签 @CacheNamespace 类 <cache> @CacheNamespaceRef 类 <cac ...
- MyBatis 常用写法
MyBatis 常用写法 1.forEach 循环 forEach 元素的属性主要有 item, idnex, collection, open, separator, close. collec ...
- Mybatis常用xml
工作中mybatis常用的xml代码 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE ma ...
- MyBatis - 常用标签与动态Sql
MyBatis常用标签 ● 定义sql语句:select.insert.delete.update ● 配置JAVA对象属性与查询结构及中列明对应的关系:resultMap ● 控制动态sql拼接:i ...
- Mybatis 常用标签
MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉 ...
- mybatis常用配置
前面两篇博客我们简单介绍了mybatis的使用,但是在mybatis的配置问题上我们只是使用了最基础的配置,本文我们就来说说其他一些常用的配置.如果小伙伴对mybatis尚不了解,可以先参考这两篇博客 ...
- [Mybatis]Mybatis 常用标签及功能整理
Mybatis中生成动态SQL的标签有四类,分别是: if choose (when, otherwise) trim (where, set) foreach 1.if 当需要动态生成where条件 ...
- mybatis常用标签
1. 定义sql语句 1.1 select 标签 属性介绍: id :唯一的标识符. parameterType:传给此语句的参数的全路径名或别名 例:com.test.poso.User或user ...
- MyBatis常用对象SqlSessionFactory和SqlSession介绍和运用
学习框架一个比较好的路径阅读源码.本文介绍的SqlSessionFactory和SqlSession.可以通过了解SqlSessionFactory接口和SqlSession接口以及两个的实现类入手, ...
- [Mybatis]Mybatis常用操作
Mybatis是目前国内比较流行的ORM框架,特点是可以写灵活的SQL语句,非常适合中小企业的面向数据库开发. 本文总结自己开发过程中常用的Mybatis操作. 一.插入操作 主键自增插入单条 < ...
随机推荐
- hash 和pushState,replaceState
hash 要点: 1.不会向后台发请求:#是用来指导浏览器动作的,对服务器端完全无用. 2.用来跳转到页面的指定位置: 为网页位置指定标识符,有两个方法.一是使用锚点,比如<a name=& ...
- Tomcat post参数长处理
如下图所示:增加maxPostSize="-1"属性即可
- Android代码书写规范
1.资源文件命名规则2.类名文件命名规则3.尽量少用枚举4.public方法.重要逻辑.主要类结构体必须注释,其他部分可自定注释5.提交代码必须描述清楚修改内容,如果一次提交内容过多,拆分功能进行多次 ...
- 【效率工具】SSH一键登录脚本(可一键从跳板机登录线上服务器)
说明 前阵子上线,一次性上了十个服务,一直上到凌晨才完事,期间每个服务都要先输入跳板机的登录信息来登录跳板机,然后再输入线上服务器的信息来登录线上服务器,实在是太过于麻烦,而且有些服务还有好几台服务器 ...
- IPD咨询如何才能真正落地?
文/资深顾问 杨学明 IPD作为先进的产品开发理念,思想起源于PRTM公司,PACE,培思的力量,首先在IBM和波音公司迅速完善,中国是深圳华为公司. 1992年IBM公司利润停止增长,财务困难,IB ...
- 使用fiddler对手机上的程序进行抓包
用fiddler对手机上的程序进行抓包,网上有很多的资料,这里写一下来进行备用. 前提: 1.必须确保安装fiddler的电脑和手机在同一个wifi环境下 备注:如果电脑用的是台式机,可以安装一个 ...
- [20181130]control file sequential read.txt
[20181130]control file sequential read.txt --//昨天上午探究了大量控制文件读的情况,链接:http://blog.itpub.net/267265/vie ...
- Mybatis 学习---${ }与#{ }获取输入参数的区别、Foreach的用法
一.Mybatis中用#{}和${}获取输入参数的区别 1.“#{}“和“${}”都可以从接口输入中的map对象或者pojo对象中获取输入的参数值.例如 <mapper namespace=&q ...
- MySQL Host is blocked because of many connection errors 解决方法
应用日志提示错误:create connection error, url: jdbc:mysql://10.45.236.235:3306/db_wang?useUnicode=true&c ...
- android 休眠唤醒机制分析(一) — wake_lock【转】
Android的休眠唤醒主要基于wake_lock机制,只要系统中存在任一有效的wake_lock,系统就不能进入深度休眠,但可以进行设备的浅度休眠操作.wake_lock一般在关闭lcd.tp但系统 ...