mybatis动态sql查询
来源:互联网 发布:笔记本温度检测软件 编辑:程序博客网 时间:2024/04/26 14:16
在实际开发中,查询条件千变万化,有时是各个条件单个进行查询,也有可能是其中两个、三个乃至更多条件组合起来进行查询,怎样用简洁的代码实现这个功能呢,刚开始想到的是在一种条件写一个方法,对应一条sql,这种方法固然能实现功能,但特别繁琐,造成代码冗余。后来想到mybatis的mapper.xml文件中用if test的条件判断,当即决定,使用动态sql进行查询。具体如下:
mapper.xml:
<!-- 根据灵活条件查看用户绑定设备详情 -->
<select id="queryUserDevices" parameterType="com.*.bean.Device" resultMap="deviceResultMap" flushCache="true">
select
<include refid="Base_Column_List" />
from pc_device
<where>
<if test="deviceType!=null and deviceType!=' ' ">
device_type = #{deviceType}
</if>
<if test="patId!=null and patId!=0">
and pat_id= #{patId}
</if>
<if test="machineId!=null and machineId!=0">
and machine_id=#{machineId}
</if>
</where>
</select>
注意:1、条件要用where标签拼接,不要用choose when otherwise或者在外面写 where 1=1,下面用<if test=" ">拼接,不然如果直接写where后面如果第一个没有,那么后面的就有and 语句不对。用where标签可以解决,过滤掉and,要记住:第一个条件不要and,后面不管有多少个条件,都用and拼接起来。
2、if test里面的是类的属性,不是字段名,if test外面才是字段名,如果在if test里放字段名,将会导致 属性no getter的异常,如果字段的类型是Integer,就是这样判断:patId!=null and patId!=0,如果是string,则这样判断deviceType!=null and deviceType!=' ',具体看各个类型没有赋值时的默认值来定。如果是模糊查询,应用like #{ } 至于多个条件,我是把它们封装成一个对象进行查询。这样,如果if条件成立,将会把对应条件拼接到where子句后面,如果if条件不成立,where 子句将会忽略这个条件。我们可以在mybatis-config.xml的配置文件中的
<settings> 节点增加这个设置:<setting name="logImpl" value="STDOUT_LOGGING" />,这样在执行到相应操作时,后台就会把sql语句打印出来,方便我们查询sql语句写得是否正确了。
- MyBatis动态sql查询
- Mybatis动态sql查询
- mybatis动态sql查询
- mybatis动态sql查询语法
- mybatis动态sql查询语法
- Mybatis动态Sql语句查询
- MyBatis动态查询 模糊查询实例sql
- MyBatis-动态sql与模糊查询 -07
- mybatis 动态SQL与模糊查询
- Mybatis 1.动态sql 2.模糊查询
- Spring+Mybatis实现动态SQL查询
- Spring+Mybatis实现动态SQL查询
- 03. mybatis 动态sql && 模糊查询
- MyBatis 实践 -动态SQL/关联查询
- Mybatis动态SQL与模糊查询
- Mybatis学习----模糊查询和动态sql
- 六、Mybatis动态SQL和模糊查询
- Mybatis之动态SQL 模糊查询
- 动态规划问题1
- 实验三:十进制转换成二进制数(顺序栈)
- 如何准确地确定 HTTP 请求的来源
- Jmeter通过POST方法测试用户登录接口
- hdu 5293 Tree chain problem【树状dp+dfs序+树状数组】
- mybatis动态sql查询
- Detection Algorithms for Communication Systems Using Deep Learning笔记
- 面向对象-接口
- 求s=a+aa+aaa+aaaa+aa...a的值
- 获取CPU信息的shell脚本
- 二分查找算法代码实现
- 软件工程(C编码实践篇)”实验报告 实验四:用可重用的链表模块来实现命令行菜单小程序V2.5
- 导入Android项目一直停留在Build的解决方法
- Freemarker中list的相关使用