最近在项目中遇到一个,需要根据传入的存有id的list,计算值,再起别名 <if test="channelList != null and channelList.size()>0"> <foreach collection="channelList" index="index" item="item" open="" separator="," close=&…
今天写sql发现了一点问题,乱弄了好久算是搞定了.关于mybatis的批量插入使用foreach插入形式为: insert into role_privilege( role_id, privilege_id,last_edit) values ( ?, ?, ? ),( ?, ?, ? ),( ?, ?, ? ): 而不不希望是这样的 insert into role_privilege( role_id, privilege_id,last_edit) values ( ?, ?, ? )…
标签太多,记一下不是特别常用的标签~留着脑袋瓜不机灵的时候看! <foreach>标签  该标签的作用是遍历集合类型的条件 <select id="countByUserList" parameterType="list"> SELECT COUNT(*) FROM users WHERE user_id IN <foreach item="userList" collection="list"…
mapper.xml如下: <select id="selectCkspcb" parameterType="java.util.Map" resultType="java.util.Map"> SELECT COALESCE (pg.goodsid, 0) spbm, COALESCE (pg.goodsname, '') spmc, COALESCE ( ( SELECT classname FROM pub_goodsclass…
背景 考虑以下场景: InfoTable(信息表): Name Gender Age Score 张三 男 21 90 李四 女 20 87 王五 男 22 92 赵六 女 19 94 孙七 女 23 88 周八 男 20 91 StatusTable(状态表,指是否有在考试之前复习): Name hasReview 张三 是 李四 否 王五 是 赵六 是 孙七 否 周八 是 现在,我想知道所有复习过的学生的成绩,可以利用mysql中的子查询来实现: SELECT Score FROM Info…
Mybatis批量insert 返回主键 Mybatis从3.3.1版本开始,支持批量插入后返回主键ID.首先对于支持自增主键的数据库使用useGenerateKeys和keyProperty,对于不支持生成自增主键的数据库使用selectKey标签.类似<MyBatis 返回insert操作主键>中单条插入. 使用批量插入,可以减少和数据库交互的次数,但是,数据量应该做一个控制,和for循环类似.首先定义Java Bean Instance: import java.io.Serializa…
MyBatis的Mapper文件的foreach标签用来迭代用户传递过来的Lise或者Array,让后根据迭代来拼凑或者批量处理数据.如:使用foreach来拼接in子语句. 在学习MyBatis Mapper文件的foreach标签时我们先看看DTD是如何定义的?DTD代码如下: <!-- 定义foreach元素 --> <!ELEMENT foreach (#PCDATA | include | trim | where | set | foreach | choose | if |…
有时候开发中需要根据多个ID去查询,可以将ID封装为List或者数组然后使用MyBatis中的foreach标签构建in条件. 这里我将ID封装为String[]作为参数. <select id="selectList" parameterType="java.util.List" resultType="java.lang.Integer"> SELECT COUNT(1) FROM t_user WHERE id IN <f…
一.批量插入数据 示例:添加订单商品表 1.模型层的相应代码 /** * 添加订单商品表 * @param ordergoods * @return */ public boolean addOrdergood(List<Ordergood> ordergoods){ return session.insert(Ordergood.class.getName()+".addOrdergood", ordergoods)>0; } 2.xml文件 <!--添加订单…
一  模板函数的使用 1.代码 效果: 函数会按照从左到右的顺序依次调用.如果你觉得这样写起来比较麻烦,也可以直接这样写:{:substr(strtoupper(md5($name)),0,3)} 默认值输出 {$user|default="这家伙很懒,什么也没留下"} 2   模板运算符 {:3+4*2-1}     效果10 {3+4*2-1}    效果   {3+4*2-1} 在使用运算符的时候,不再支持点语法和常规的函数用法,例如:{$user.score+10} //错误的…