java 查询条件的封装_mybatis-plus QueryWrapper自定义查询条件的实现

本文介绍了如何在mybatis-plus中利用QueryWrapper动态构建查询条件,避免XML中复杂的if判断。通过前端提交查询参数,后端解析并使用QueryWrapper的eq、like等方法动态生成SQL WHERE子句,实现灵活的查询功能。同时提醒注意mybatis-plus的版本选择和排序问题。
摘要由CSDN通过智能技术生成

mybatis-plus框架功能很强大,把很多功能都集成了,比如自动生成代码结构,mybatis crud封装,分页,动态数据源等等,附上官网链接,github上有代码例子,国内小伙伴推荐码云。

但是,其中还是有些小坑,文档也没有涉及的很全面,碰到问题,百度或者发issue,能力强的还是直接看源码好,一切答案都在源码中。

版本推荐用3.1.0,3.1.1及以上版本有bug,访问mapper接口的时候,会把数据库date类型转换为localdatetime,报错java.sql.sqlfeaturenotsupportedexception

解决方案可以参考

com.baomidou

mybatis-plus-boot-starter

3.1.0

mybatis-plus里有个类querywrapper,封装sql对象,包括where条件,order by排序,select哪些字段等等。该类的具体用法,网上教程很多。

这里有个需求,通过前端提交查询条件,后台动态拼接成where的sql语句,用于查询。常规做法是前端提交一堆查询参数,controller层用一个对象接收,然后在mybatis的xml里对该对象里的各种属性做判断

select * from test

and name=#{name}

...

这有个问题是具体字段连接类型就有很多,like,=,>,

前端

前端用的技术是html+jquery,jquery操作dom做各种操作。html就仅仅是样式展现,不涉及任何的逻辑代码,没有使用vue之类的mvvm框架,也没有使用thymeleaf之类的模板引擎,其实这些都会在html嵌入污染代码,导致美工修改页面样式的时候一脸蒙蔽。html就是纯的html+css,通过jquery来完成剩余的工作。

index.html

jquery发起post请求,拼接的参数如下:

var searchparam = [

{column: "column_name",type: "like", value: "tim"},

{column: "column_age",type: "eq", value: "22"},

{column: "column_date",type: "ge", value: "2019-08-16 00:00:00"},

{column: "column_date",type: "le", value: "2019-08-16 23:59:59"}

];

其中column值 为数据表的字段名;type值为sql字段拼接的方式,规则可自己定制;value就是字段值了;目标拼接成的sql语句如下ÿ

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值