欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

mybatis写sql话语注意

更新时间: 2014-01-05 02:08:03 责任编辑: Author_N1

 

Mybatis写SQL语句注意


1.mybatis where 动态查询时,首个查询语句的首个单词中不要出现sql的关键字
 比如:

    <where>
            <if test="orgIds !=null">
                org.id IN
                <foreach collection="orgIds" item="item" index="index" open="("
                    separator="," close=")">
                    #{item}
                </foreach>
            </if>
         AND coupon.isdel = 0
        </where>

    其中org 的前两个字母是 or ,和sql的关键字 OR 是一样的所以会截取 按 g.id IN 来查询

   

解决方案:
    和 coupon.isdel = 0 调换一下位置便可(屏蔽关键字):

            <where>
            coupon.isdel = 0
            <if test="orgIds !=null">
                AND org.id IN
                <foreach collection="orgIds" item="item" index="index" open="("
                    separator="," close=")">
                    #{item}
                </foreach>
            </if>
        </where>


   

上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:08:03
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/6034/
本文WWW.DOC100.NET DOC100.NET版权所有。