Mybatis的mapper.xml的传值和<if></if>标签的使用(学习分享)
来源:互联网 发布:网站源码可以干吗 编辑:程序博客网 时间:2024/04/30 14:13
SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序):
- cache – 配置给定命名空间的缓存。
- cache-ref – 从其他命名空间引用缓存配置。
- resultMap – 最复杂,也是最有力量的元素,用来描述如何从数据库结果集中来加载你的对象。
- parameterMap – 已经被废弃了!老式风格的参数映射。内联参数是首选,这个元素可能在将来被移除。这里不会记录。
- sql – 可以重用的 SQL 块,也可以被其他语句引用。
- insert – 映射插入语句
- update – 映射更新语句
- delete – 映射删除语句
- select – 映射查询语句
select
查询操作在我看来相比于其他的操作算得上操作最频繁的操作,对于每次插入,更新或删除,那也会有很多的查询。对简单类别的查询元素是非常简单的。比如:
<select id="selectOneEle" parameterType="int" resultType="map"> SELECT * FROM Table(表) WHERE ID = #{id}</select>
这里使用的#{id}直接接收参数,对于基本数据类型的数据也可以使用#{value}来接收参数。
在log日志文件中我们可以来看到打印的sql语句为:
SELECT * FROM Table(表) WHERE ID = ? 这里的“?”就是写入接收到的id的值。
Select Attributes
属性 描述 id 在命名空间中唯一的标识符,可以被用来引用这条语句。 parameterType 将会传入这条语句的参数类的完全限定名或别名。 parameterMap 这是引用外部 parameterMap 的已经被废弃的方法。使用内联参数映射和 parameterType 属性。 resultType 从这条语句中返回的期望类型的类的完全限定名或别名。注意集合情形,那应该是集合可以包含的类型,而不能是集合本身。使用 resultType 或 resultMap,但不能同时使用。 resultMap 命名引用外部的 resultMap。返回 map 是 MyBatis 最具力量的特性, 对其有一个很好的理解的话, 许多复杂映射的情形就能被解决了。使用 resultMap 或 resultType,但不能同时使用。 flushCache 将其设置为 true,不论语句什么时候被带哦用,都会导致缓存被清空。默认值:false。 useCache 将其设置为 true, 将会导致本条语句的结果被缓存。默认值: true。 timeout 这个设置驱动程序等待数据库返回请求结果,并抛出异常时间的最大等待值。默认不设置(驱动自行处理) fetchSize 这是暗示驱动程序每次批量返回的结果行数。默认不设置(驱动自行处理)。 statementType STA TEMENT,PREPARED 或 CALLABLE 的一种。这会让 MyBatis 使用选择使用 Statement,PreparedStatement 或 CallableStatement。默认值:PREPARED。 resultSetType FORWARD_ONLY|SCROLL_SENSITIVE|SCROLL_INSENSITIVE 中的一种。默认是不设置(驱动自行处理)。 databaseId In case there is a configured databaseIdProvider, MyBatis will load all statements with no databaseId attribute or with a databaseId that matches the current one. If case the same statement if found with and without the databaseId the latter will be discarded.insert, update and delete
<insert id="insertAuthor" parameterType="domain.blog.Author" flushCache="true" statementType="PREPARED" keyProperty="" keyColumn="" useGeneratedKeys="" timeout="20000"> <update id="insertAuthor" parameterType="domain.blog.Author" flushCache="true" statementType="PREPARED" timeout="20000"> <delete id="insertAuthor" parameterType="domain.blog.Author" flushCache="true" statementType="PREPARED" timeout="20000">
Insert, Update and Delete Attributes
属性 描述 id 在命名空间中唯一的标识符,可以被用来引用这条语句。 parameterType 将会传入这条语句的参数类的完全限定名或别名。 parameterMap 这是引用外部 parameterMap 的已经被废弃的方法。使用内联参数映射和 parameterType 属性。 flushCache 将其设置为 true,不论语句什么时候被带哦用,都会导致缓存被清空。默认值:false。 timeout 这个设置驱动程序等待数据库返回请求结果, 并抛出异常时间的最大等待值。默认不设置(驱动自行处理)。 statementType STA TEMENT,PREPARED 或 CALLABLE 的一种。这会让 MyBatis 使用选择使用 Statement,PreparedStatement 或 CallableStatement。默认值:PREPARED。 useGeneratedKeys ( 仅 对 insert 有 用 ) 这 会 告 诉 MyBatis 使 用 JDBC 的 getGeneratedKeys 方法来取出由数据(比如:像 MySQL 和 SQL Server 这样的数据库管理系统的自动递增字段)内部生成的主键。默认值:false。 keyProperty (仅对 insert 有用) 标记一个属性, MyBatis 会通过 getGeneratedKeys 或者通过 insert 语句的 selectKey 子元素设置它的值。默认: 不设置。 keyColumn (仅对 insert 有用) 标记一个属性, MyBatis 会通过 getGeneratedKeys 或者通过 insert 语句的 selectKey 子元素设置它的值。默认: 不设置。<insert id="insertAuthor" parameterType="domain.blog.Author"> insert into Author (id,username,password,email,bio) values (#{id},#{username},#{password},#{email},#{bio})</insert><update id="updateAuthor" parameterType="domain.blog.Author"> update Author set username = #{username}, password = #{password}, email = #{email}, bio = #{bio} where id = #{id}</update> <delete id="deleteAuthor" parameterType="int"> delete from Author where id = #{id}</delete>
以上是在学习中用到的资料。
关于标签的使用
在mapper.xml中很容易用到条件判断,今天遇到了if简单的学习后做下分享,例子很简单,在controller层传来参数String WEIGHT_ID,String PRESCRIPTIONBATCH_ID。其中的String PRESCRIPTIONBATCH_ID=null
public String delWeightIsUsed(HttpServletRequest request,String WEIGHT_ID,String PRESCRIPTIONBATCH_ID){ Map<String, String> param=new HashMap<>(); param.put("WEIGHT_ID", WEIGHT_ID); param.put("PRESCRIPTIONBATCH_ID", PRESCRIPTIONBATCH_ID);//空值 RelprescriptionbatchWeight relprebatch=new RelprescriptionbatchWeight(); relprebatch=relprescriptionbatchWeightService.selectByWeightAndPrebatchId(param);//查询,参数param,在下面的mapper中有此selectByWeightAndPrebatchId return null;}
在另外一个controller中,传来参数String WEIGHT_ID,String PRESCRIPTIONBATCH_ID。其中的String PRESCRIPTIONBATCH_ID!=null
public String getCustomWeight(HttpServletRequest request,String PRESCRIPTIONBATCH_ID){ List<Weight> listWeight=new ArrayList<Weight>(); listWeight=weightService.selectAll(); List<Map<String, Object>> listMap=new ArrayList<Map<String, Object>>(); for(Weight weight:listWeight){ Map<String, String> param=new HashMap<>();//map集合 Map<String, Object>map=new HashMap<>(); param.put("WEIGHT_ID", weight.getWEIGHT_ID());//放入参数 param.put("PRESCRIPTIONBATCH_ID", PRESCRIPTIONBATCH_ID);//放入参数,不是空,上面的对比例子中为空 RelprescriptionbatchWeight reWeight=new RelprescriptionbatchWeight(); reWeight = relprescriptionbatchWeightService.selectByWeightAndPrebatchId(param);//查询,参数param,在下面的mapper中有此selectByWeightAndPrebatchId if(reWeight!=null){ map.put("relWeight", reWeight); map.put("weight", weight); }else{ map.put("relWeight", null); map.put("weight", weight); } listMap.add(map); } request.setAttribute("PRESCRIPTIONBATCH_ID", PRESCRIPTIONBATCH_ID); request.setAttribute("listMap", listMap); return "matching/customWeight"; }
mapper.xml请注意test中的判断条件直接写的传来的值,这和jsp中的<c:if test="${PRESCRIPTIONBATCH_ID!=null}"></c:if>
不同
<select id="selectByWeightAndPrebatchId" parameterType="map" resultMap="BaseResultMap"> select <include refid="Base_Column_List"/> from RELPRESCRIPTIONBATCH_WEIGHT where WEIGHT_ID=#{WEIGHT_ID} <if test="PRESCRIPTIONBATCH_ID!=null and PRESCRIPTIONBATCH_ID!=''"> and PRESCRIPTIONBATCH_ID=#{PRESCRIPTIONBATCH_ID} </if></select>
通过这种方法有效的提高的代码的复用,对于不同的参数值判断执行相应的sql操作。例子很简单,抛砖引玉了!
2 0
- Mybatis的mapper.xml的传值和<if></if>标签的使用(学习分享)
- Mybatis的Mapper.xml中<if test>报NumberFormatException
- My Batis mapper.xml中 动态SQL中使用trim标签 if end的场景
- mybatis的动态SQL(一)if标签的使用
- Mybatis的<where><if>标签
- 简单标签的if和 if-else使用代码
- Mybatis中xml对if标签中文判断的处理
- struts的if标签使用
- <c:if>标签的使用
- c:if标签的使用
- mapper映射器中if标签的应用
- <s:if>标签和<c:if>标签的一点区别
- if和else if的使用注意事项
- if......if和if......else if......else if的区别
- mybatis xml文件中传入参数和if结合使用时要注意的地方
- Mybatis 框架使用的最核心内容(二):mapper.xml中常用的标签详解
- Mybatis 框架使用的最核心内容(二):mapper.xml中常用的标签详解
- Mybatis 框架使用的最核心内容(二):mapper.xml中常用的标签详解
- Eclipse编码格式
- 卷积神经网络与图像识别基本概念
- qqqqqqqqqqqqqqqqqqqqqqqqqq
- PHP读取excel文档
- 升压恒流驱动 120W大功率驱动
- Mybatis的mapper.xml的传值和<if></if>标签的使用(学习分享)
- css中的ul>li
- 判断语句switch - case 和if - else
- 深入理解HTTP Session
- GCD入门(三): Dispatch Sources( 含demo)
- RabbitMQ三种Exchange模式(fanout,direct,topic)的性能比较
- FPGA configuration is not done on the target
- shell脚本按照进程名称杀死进程
- TCP 滑动窗口(发送窗口和接收窗口)