mybatis :Criteria 查询、条件过滤用法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。

PS:hibernate 中也有 Criteria 的用法,见另一文章:jpa : criteria 作排除过滤、查询

1. 包:

import tk.mybatis.mapper.entity.Example;
import tk.mybatis.mapper.entity.Example.Criteria;

2. 使用:

    public void getQueryExampleByCondition(Example example, OrderQuery query) {Criteria criteria1 = example.createCriteria();// 设置 criteria2 与 criteria1 为 or 方式关联Criteria criteria2 = example.or(); if (query != null) {if (query.getLoadSrc() != null && query.getLoadSrc() != -1) {criteria1.andEqualTo("loadSrc", query.getLoadSrc());}if (!StringUtil.isEmpty(query.getOrderNo())) {criteria1.andLike("orderNo", "%" + query.getOrderNo() + "%");}// 以下 3 个会用 OR 方式加上 criteria2 中的条件if (query.getStatus() != null && query.getStatus() != -1) {criteria1.andEqualTo("status", query.getStatus());criteria2.andEqualTo("status", query.getStatus());}if (!StringUtil.isEmpty(query.getRepayDateEnd())) {criteria1.andLessThanOrEqualTo("repayDate", query.getRepayDateEnd());criteria2.andLessThanOrEqualTo("repayDate", query.getRepayDateEnd());}if (!StringUtil.isEmpty(query.getLoanDay())) {criteria1.andEqualTo("loanDay", query.getLoanDay());criteria1.andEqualTo("loanDay", query.getLoanDay());}}}

其中 criteria1 和 criteria2  是 or 的关系。

根据传入参数不同,执行 sql 效果类似:

SELECT * FROM xxxx WHERE (load_type = 5 AND loan_day = 7) OR (order_No = 5) 

where 后面第一个圆括号中的条件组合 load_type = 5 AND loan_day = 7 是 criteria1中的条件,

第二个圆括号中的条件 order_No = 5 是 criteria2 中的条件设置。

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++11多线程----线程管理

说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段。并行是指两个或多个独立的操作同时进行。注意这里是同时进行,区别于并发,在一个时间段内执行多个操作。在单核时代&#xff0…

揭秘赚钱的技巧,学会让钱自己进来

学习把负债变为资产 贫穷是一种习惯,而不只是口袋里金钱的多寡。 每个人每天的时间是相同的,有人利用它来打工,赚取约80新台币的工资。也有人将时间用来教书,每小时赚取约500新台币,也有人用这些时间来上网&#xff0c…

Shell编程入门基础上

前言 为什么学 Shell Shell 脚本语言是实现 Linux/UNIX 系统管理及自动化运维所必备的重要工具, Linux/UNIX 系统的底层及基础应用软件的核心大都涉及 Shell 脚本的内容。每一个合格 的Linux 系统管理员或运维工程师,都需要能够熟练地编写 Shell 脚本语言…

宝宝不开心 : 减肚子大战进行中、持续更新,看看一个月后能不能把腰瘦下来 ...

公司研发中心离家很近,于是来这边后就天天回家吃吃、喝喝、睡睡 ... 中午一个半小时休,吃完就滚上床铺:睡午觉,就这样 天天过得好不惬意 ... // 每周也会发零售,大家都吃得乐呵呵的,晚上加班都是组上好些个…

内存问题提醒!结构体+protobuf做协议体发送!序列化

内存的三种分配方式: 1. 从静态存储区分配:此时的内存在程序编译的时候已经分配好,并且在程序的整个运行期间都存在。全局变量,static变量等在此存储。 2. 在栈区分配:相关代码执行时创建&…

穷人迈向富翁的理财十步曲

当你每日的储蓄随着时间的累积,达到一定数量后再转存到存款薄里,如此日积月累,就可以逐渐养成自身存钱理财的习惯。不管你做什么事情,是否养成了良好的习惯,都会决定你的成败。理财投资也是同样道理,在你养…

【融云分析】选择IM云服务,需要看哪些核心技术指标?

IM(即时通讯)云服务已发展数年,不少企业与开发者都倾向于选择第三方IM云服务,短平快地为应用添加即时通讯能力,但如何选择服务商却是个难题,单从简单的功能介绍来看无法判断,因为IM云服务接入后…

Nginx 配置详解

序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的。从2004年发布至今,凭借开源的力量,已经接近成熟与完善。 Nginx功能丰富,可作为HTTP服务器,也可作为反向代理服务器,邮件服务器。支持FastCGI…

protocol buffers使用说明

一、什么是protocol buffers Protocol buffers是一个灵活的、高效的、自动化的用于对结构化数据进行序列化的协议,与XML相比,Protocol buffers序列化后的码流更小、速度更快、操作更简单。你只需要将要被序列化的数据结构定义一次(译注:使用…

jeeCMS首页加载流程

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gyshun/article/details/79669293 如果JEECMS部署完毕之后,在浏览器中输入http://localhost:8080/jeecms,系统直接会按照以下步骤执行: 首…

车子突然溜坡追尾 驾校教练说挂P挡拉手刹不会溜坡

昨天4:44,朱先生来电:刚才登云路一个烧烤店门口,一辆车停在自己的车位上的,不知什么原因,突然溜坡撞上前面的一辆出租车。稀奇的是,这个溜坡的驾驶员全程都是车上睡觉睡着的,什么都不知道。记者…

VSCode 汉化、设置为 中文语言显示 、中文界面

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。 Vscode是一款开源的跨平台编辑器。默认情况下,vscode使用的语言为英文(us),如何将其显示语言修改成中文了&#…

c++执行vbs脚本

#include<fstream> using namespace std;int main() {fstream out("StartIE.vbs",ios::out);out<<"AppName\"启动IE\"\n\Set WshellWScript.CreateObject(\"WScript.Shell\")\n\Set ieWScript.CreateObject(\"InternetEx…

Python-21-socket编程

一、基础知识 1. C/S架构 C/S架构即客户机/服务器模式。 它可以分为客户机和服务器两层&#xff1a; 第一层: 在客户机系统上结合了界面显示与业务逻辑&#xff1b; 第二层: 通过网络结合了数据库服务器。 简单的说就是第一层是用户表示层&#xff0c;第二层是数据库层。 这里…

解决:VScode 汉化后 、设置中文后 还显示英文的问题

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 按f1 搜索 Configore Display Language 设置 zh-cn 关闭软件重启。 如果重启菜单等还是英文的&#xff0c;在商店查看已安装的插件&…

自动挡怎么开-自动挡汽车怎么开?

汽车改用自动变速器后&#xff0c;驾驶员的操作更加简便、驾驶更加平顺&#xff0c;因此装备自动变速器的新型轿车尤其受到了人们的青睐。不过&#xff0c;很多驾驶者初开自动挡车时&#xff0c;由于对自动变速器的结构和原理不是很了解&#xff0c;行车时经常是一个D挡走完全程…

CreateThread函数

创建一个在调用进程的虚拟地址空间内执行的线程。 要创建在另一个进程的虚拟地址空间中运行的线程&#xff0c;请使用 CreateRemoteThread函数。 语法 HANDLE CreateThread(LPSECURITY_ATTRIBUTES lpThreadAttributes,SIZE_T dwStackSize,LPTHREAD_START…

nginx 的请求处理、请求的处理流程

nginx的请求处理 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 nginx使用一个多进程模型来对外提供服务&#xff0c;其中一个master进程&#xff0c;多个worker进程。master进程负责…

如何控制油门更准确?

学员问&#xff1a;平时练车还不错&#xff0c;可是一换车就容易加大油门&#xff0c;有什么方法能很好的控制油呢&#xff1f;&#xff1f; 如何控制油门更准确&#xff1f;和调的座位有关系吗&#xff1f;&#xff1f; 答&#xff1a;油门跟刹车被视为汽车控制的灵魂。汽车发…

使用线程——创建线程

CreateThread函数创建一个进程的新的线程。创建线程必须指定新线程要执行的代码的起始地址。通常&#xff0c;起始地址是程序代码中定义的函数的名称&#xff08;有关更多信息&#xff0c;请参阅ThreadProc&#xff09;。此函数采用单个参数并返回DWORD值。一个进程可以让多个线…