巧妙mybatis避免Where 空条件的尴尬

您所在的位置:网站首页 查询为空的字段的sql语句 巧妙mybatis避免Where 空条件的尴尬

巧妙mybatis避免Where 空条件的尴尬

2024-06-07 16:58| 来源: 网络整理| 查看: 265

我就废话不多说了,大家还是直接看代码吧~

SELECT * FROM BLOG WHERE state = #{state}

如果state参数为空时,最终生成SQL语句为

SELECT * FROM BLOG

WHERE

执行会出错,当然,你可以在where 后加一个1=1,改成

SELECT * FROM BLOG WHERE 1=1 and state = #{state}

但是这种做法有一个最大的弊端,就是导致数据表上的索引失效,如果有索引的话。而且还是一个垃圾条件

所以正确的做法应该是:

使用标签 解决这个问题

where标签会自动处理第一个为null时候的and问题

SELECT * FROM BLOG and state = #{state}

在这里插入图片描述

补充知识:mybatis @Select注解中当参数为空则不添加该参数的判断

如下所示:

@Select("select * from “+DEPTTABLE+” ")

List selectAllDept();

在mybatis中不用xml文件的形式,selectDept方法执行的就是上面的Sql语句,如果是遇到动态的语句就需要用到下面的形式。

1.用Provider去实现SQL拼接:

@SelectProvider(type=DeptDynaSqlProvider.class,method="count") Integer count(Map params); //DeptDynaSqlProvider.class 类中的方法 public String count(Map params){ return new SQL(){{SELECT("count(*)");FROM(DEPTTABLE);if(params.get("dept") != null){Dept dept = (Dept) params.get("dept");if(dept.getName() != null && !dept.getName().equals("")){WHERE(" name LIKE CONCAT ('%',#{dept.name},'%') ");}}}}.toString();}

2.还有一种方式是用script标签包围,像xml语法一样书写

@Select({"", "SELECT * FROM tbl_order", "WHERE 1=1", "", "AND mydate = #{mydate}", "", ""})

**注意:**方式1有个隐患就是当传入参数为空的时候,可能会造成全表查询。

复杂SQL用方式2会比较灵活(当然,并不建议写复杂SQL),而且可以抽象成通用的基类,使每个DAO都可以通过这个基类实现基本的通用查询,原理类似Spring JDBC Template。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3