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.pswp.cn/news/448234.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448234.shtml
英文地址,請注明出處:http://en.pswp.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值。一個進程可以讓多個線…