今天刚刚学习了mybatis,做了简单的对数据库的增删改查。在进行删除操作时,单条删除时很简单,但是批量删除的时候拼接删除条件却有些麻烦,现记录一下做法。
Sql语句中,当删除条件并不唯一的时候,我们有两种删除的sql语句,一种使用or拼接where中的条件,例如delete from 表名where 条件1 or 条件2,另一种是使用in 例如delete from 表名where 元素in( )
利用第一种删除语句在mybatis中的mapping.xml中进行拼接:
利用第二种删除语句在mybatis中的mapping.xml中进行拼接:
以上删除操作基本完成,但是,这样有一个缺陷,当查询条件idList中没有元素的时候,会删除整个表ac01中的记录。所以,我们需要对上述方法进行改进。
第二种删除语句进行改进后:
第一种删除语句进行改进后:
至此,删除操作完美完成。
补充知识:myBatis 查询时注意and拼接条件
<!-- 加个条件 -->
<sql id="queryjiachaAllPageId"> <where> <if test="danweimc !=null and danweimc !=''"> and jcb.danweimc like '%${danweimc}%' </if> <if test="ge_jianchaks !=null and ge_jianchaks !=''"> and DATE_FORMAT(jcb.jianchaks, '%Y-%m-%d') >= #{ge_jianchaks} </if> <if test="le_jianchaks != null and le_jianchaks != ''"> and DATE_FORMAT(jcb.jianchaks, '%Y-%m-%d') <= #{le_jianchaks} </if> <if test="jiancharxm !=null and jiancharxm !=''"> and jcb.jiancharxm like '%${jiancharxm}%' </if> <if test="zhuangtai !=null and zhuangtai !=''"> and yhb.zhuangtai = ${zhuangtai} </if> <if test="danweilb !=null and danweilb !=''"> and yhb.yinhuanmc like '${danweilb}%' </if> <if test="jiedao != null and jiedao !='' and jiedao !='110105000000'"> and jcb.jiedao=#{jiedao} </if> <if test="danweimcs != null and danweimcs !=''"> and jcb.danweimc = #{danweimcs} </if> </where> </sql>
例如上诉问题 要么都加and ,要么都不加 ,一定要注意,如果有加and 和没有加and的 查询会报错
以上这篇解决myBatis中删除条件的拼接问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
myBatis,删除条件拼接
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。