mybatis where用法,mybatis <是什么
目录
米巴提斯在哪里标签的使用进阶:自定义整齐标签在哪里语句的坑小结我们经常在动态构造结构化查询语言时,为防止注入或防止语句不当时会使用其中1=1
select id= selectGroupByEmployeeNum 结果映射=基本结果映射参数类型= com。道。impl。zchatgroup select * from ZC聊天组其中如果test=id!=null id=# { id }/if if test= leader num!=null 和leader _ num=# { leader num }/if if test= group type!=null 和group _ type=# { group type }/if/select但在使用在哪里标签可以简化这条语句
select id= selectGroupByEmployeeNum 结果映射=基本结果映射参数类型= com。道。impl。zchatgroup select * from ZC聊天组where if test= id!=null id=# { id }/if if test= leader num!=null 和leader _ num=# { leader num }/if if test= group type!=null 和group _ type=# { group type }/if/where/select这条结构化查询语言执行时,如果编号这个参数为空,则这条语句的执行结果为
select * from zc_chat_group其中leader_num=xx 和group_type=xx 这个哪里标签会知道如果它包含的标签中有返回值的话,它就会插入一个哪里.此外,如果标签返回的内容是以和或运筹学开头的,则会把它去除掉。
Mybatis where标签的使用
为了能达到关系型数据库性能的调优,我们可以基于框架的在哪里标签来进行实现哪里?标签是顶层的遍历标签,需要配合如果标签使用,单独使用无意义。通常有下面两种实现形式。
方式一:
select id= select selective 结果类型= com。二哥。实体。user select * from t _ user where if test= username!=空和用户名!= username=# { username }/if if test= idNo!=空和idNo!= 和id_no=#{idNo} /if /where /select方式二:
select id= select selective 结果类型= com。二哥。实体。user select * from t _ user where if test= username!=空和用户名!= 和username=# { username }/if if test= idNo!=空和idNo!= 和id_no=#{idN
o} </if> </where> </select>仔细观察会发现,这两种方式的区别在于第一if条件中的SQL语句是否有and。
这里就涉及到where标签的两个特性:
第一,只有if标签有内容的情况下才会插入where子句;第二,若子句的开通为 AND 或 OR,where标签会将它替换去除;所以说,上面的两种写法都是可以了,Mybatis的where标签会替我们做一些事情。但需要注意的是:where标签只会 智能的去除(忽略)首个满足条件语句的前缀。所以建议在使用where标签时,每个语句都最好写上 and 前缀或者 or 前缀,否则像以下写法就会出现问题:
<select id="selectSelective" resultType="com.secbro.entity.User"> select * from t_user <where> <if test="username != null and username != "> username = #{username} </if> <if test="idNo != null and idNo != "> id_no = #{idNo} </if> </where> </select>
生成的SQL语句如下:
select * from t_user WHERE username = ? id_no = ?
很显然,语法是错误的。因此,在使用where标签时,建议将所有条件都添加上and或or;
进阶:自定义trim标签
上面使用where标签可以达到拼接条件语句时,自动去掉首个条件的and或or,那么如果是其他自定义的关键字是否也能去掉呢?此时,where标签就无能为力了,该trim标签上场了,它也可以实现where标签的功能。
<select id="selectSelective" resultType="com.secbro.entity.User"> select * from t_user <trim prefix="where" prefixOverrides="and or "> <if test="username != null and username != "> and username = #{username} </if> <if test="idNo != null and idNo != "> and id_no = #{idNo} </if> </trim> </select>
将上面基于where标签的写改写为trim标签,发现执行效果完全一样。而且trim标签具有了更加灵活的自定义性。
where语句的坑
另外,在使用where语句或其他语句时一定要注意一个地方,那就是:注释的使用。先来看例子:
<select id="selectSelective" resultType="com.secbro.entity.User"> select * from t_user <where> <if test="username != null and username != "> and username = #{username} </if> <if test="idNo != null and idNo != "> /* and id_no = #{idNo}*/ and id_no = #{idNo} </if> </where> </select>
上述SQL语句中添加了 /**/的注释,生成的SQL语句为:
select * from t_user WHERE username = ? /* and id_no = ?*/ and id_no = ?
执行时,直接报错。
还有一个示例:
<select id="selectSelective" resultType="com.secbro.entity.User"> select * from t_user <where> <if test="username != null and username != "> -- and username = #{username} and username = #{username} </if> <if test="idNo != null and idNo != "> and id_no = #{idNo} </if> </where> </select>
生成的SQL语句为:
select * from t_user WHERE -- and username = ? and username = ? and id_no = ?
同样会导致报错。
这是因为我们使用 XML 方式配置 SQL 时,如果在 where 标签之后添加了注释,那么当有子元素满足条件时,除了 < !-- --> 注释会被 where 忽略解析以外,其它注释例如 // 或 /**/ 或 -- 等都会被 where 当成首个子句元素处理,导致后续真正的首个 AND 子句元素或 OR 子句元素没能被成功替换掉前缀,从而引起语法错误。同时,个人在实践中也经常发现因为在XML中使用注释不当导致SQL语法错误或执行出错误的结果。强烈建议,非必要,不要在XML中注释掉SQL,可以通过版本管理工具来追溯历史记录和修改。
小结
本文基于Mybatis中where标签的使用,展开讲了它的使用方式、特性以及拓展到trim标签的替代作用,同时,也提到了在使用时可能会出现的坑。内容虽然简单,但如果能够很好地实践、避免踩坑也是能力的体现。
到此这篇关于mybatis where 标签使用的文章就介绍到这了,更多相关mybatis where标签内容请搜索盛行IT以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。