mybatis判断集合长度

使用mybatis框架在写sql的时候碰到一个异常:

1
1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1

  类似于sql这样出现的异常

1
SELECT * FROM eval_question  WHERE   id not in()

  后来就查询前先判断前台传入集合如果长度小于0就不走下面的操作。就不会异常了。

1
2
3
4
5
6
7
8
9
<select id="NotInByEvalQuestion" resultType="com.rm.eval.entity.EvalQnQuestion">
       SELECT * FROM eval_question  WHERE  1=1
       <if test="null != strlist and strlist.size > 0">
         and  id not in
           <foreach collection="strlist" index="index" item="item" open="(" separator="," close=")">
               #{item}
           </foreach>
       </if>
   </select>

  相当于

1
SELECT * FROM eval_question  WHERE   id not in("")或者SELECT * FROM eval_question  WHERE  1=1

 

posted @   三号小玩家  阅读(10264)  评论(1编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
Title
三号小玩家的 Mail: 17612457115@163.com, 联系QQ: 1359720840 微信: QQ1359720840

喜欢请打赏

扫描二维码打赏

支付宝打赏

点击右上角即可分享
微信分享提示