欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis-plus QueryWrapper and or 連用并且實現(xiàn)分頁

 更新時間:2022年01月11日 11:20:00   作者:Try and try again  
這篇文章主要介紹了mybatis-plus QueryWrapper and or 連用并且實現(xiàn)分頁,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

QueryWrapper and or 連用并分頁

Page<TestEntity> rpage =
 	baseMapper.selectPage(
            new Page<>(pageBean.getPageSize(), pageBean.getPageNum()),
            new QueryWrapper<TestEntity>()
                .eq("siteid", siteid)
                .and(
                    wrapper ->
                        wrapper
                            .or()
                            .lt("createtime", updatetime)
                            .or()
                            .lt("deletetime", updatetime)
                            .or()
                            .lt("operatetime", updatetime)
                            .or()
                            .lt("updatetime", updatetime)));


and or 拼完后的結(jié)果是這樣的

new QueryWrapper<TestEntity>()
? ? ? ? ? ? ? ? .eq("siteid", siteid)
? ? ? ? ? ? ? ? .and(
? ? ? ? ? ? ? ? ? ? wrapper ->
? ? ? ? ? ? ? ? ? ? ? ? wrapper
? ? ? ? ? ? ? ? ? ? ? ? ? ? .or()
? ? ? ? ? ? ? ? ? ? ? ? ? ? .lt("createtime", updatetime)
? ? ? ? ? ? ? ? ? ? ? ? ? ? .or()
? ? ? ? ? ? ? ? ? ? ? ? ? ? .lt("deletetime", updatetime)
? ? ? ? ? ? ? ? ? ? ? ? ? ? .or()
? ? ? ? ? ? ? ? ? ? ? ? ? ? .lt("operatetime", updatetime)
? ? ? ? ? ? ? ? ? ? ? ? ? ? .or()
? ? ? ? ? ? ? ? ? ? ? ? ? ? .lt("updatetime", updatetime)))
SELECT
	* 
FROM
	t 
WHERE
	useflag = 1 
	AND (
		siteid =? 
		AND (
			createtime < ? 
			OR deletetime < ? 
		OR operatetime < ? 
	OR updatetime < ?))

使用or和and的問題

最近在使用MyBatis Plus,發(fā)現(xiàn)在拼接條件的時候,and和or會出問題

比如下面這種

QueryWrapper<User> userWrapper = new QueryWrapper<User>();
userWrapper.eq("name", name);
userWrapper.eq("pwd", pwd).or().eq("phone", phone);

這種寫法拼出來的SQL語句是這樣的

select * from user where (name = ? and pwd= ? or phone = ?)

這樣子是肯定不行的,于是去官網(wǎng)查詢,發(fā)現(xiàn)正確的寫法是這樣的

QueryWrapper<User> userWrapper = new QueryWrapper<User>();
userWrapper.eq("name", name);
userWrapper.and(wrapper -> wrapper.eq("pwd", pwd).or().eq("phone", phone));
select * from user where name = ? and ( pwd= ? or phone = ?)

萬事大吉?。?!

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 淺析Spring基于注解的AOP

    淺析Spring基于注解的AOP

    Spring是一個廣泛應(yīng)用的框架,SpringAOP則是Spring提供的一個標準易用的aop框架,依托Spring的IOC容器,提供了極強的AOP擴展增強能力,對項目開發(fā)提供了極大地便利
    2022-11-11
  • Scala求和示例代碼

    Scala求和示例代碼

    這篇文章主要介紹了Scala求和示例代碼,需要的朋友可以參考下
    2019-06-06
  • 如何在mapper文件中使用in("str1","str2")

    如何在mapper文件中使用in("str1","str2")

    這篇文章主要介紹了如何在mapper文件中使用in("str1","str2"),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Java實現(xiàn)查找算法的示例代碼(二分查找、插值查找、斐波那契查找)

    Java實現(xiàn)查找算法的示例代碼(二分查找、插值查找、斐波那契查找)

    查找就是根據(jù)給定的某個值,在查找表中確定一個其關(guān)鍵字等于給定值的數(shù)據(jù)元素。本文介紹了常見的數(shù)據(jù)查找算法:順序查找、二分查找、插值查找和斐波那契查找等以及相應(yīng)的Java代碼實現(xiàn)。需要的可以參考一下
    2022-01-01
  • Java利用隨機分錢模擬財富變化

    Java利用隨機分錢模擬財富變化

    這篇文章主要為大家詳細介紹了Java如何利用隨機分錢思想模擬財富的變化,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2022-12-12
  • Java Session會話追蹤原理深入分析

    Java Session會話追蹤原理深入分析

    web開發(fā)階段我們主要是瀏覽器和服務(wù)器之間來進行交互。瀏覽器和服務(wù)器之間的交互就像人和人之間進行交流一樣,但是對于機器來說,在一次請求之間只是會攜帶著本次請求的數(shù)據(jù)的,但是可能多次請求之間是會有聯(lián)系的,所以提供了會話機制
    2022-11-11
  • java 將 list 字符串用逗號隔開拼接字符串的多種方法

    java 將 list 字符串用逗號隔開拼接字符串的多種方法

    這篇文章主要介紹了java 將 list 字符串用逗號隔開拼接字符串,本文給大家分享四種方法,每種方法通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • 一小時迅速入門Mybatis之實體類別名與多參數(shù) 動態(tài)SQL

    一小時迅速入門Mybatis之實體類別名與多參數(shù) 動態(tài)SQL

    這篇文章主要介紹了一小時迅速入門Mybatis之實體類別名與多參數(shù) 動態(tài)SQL,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • springboot 啟動時初始化數(shù)據(jù)庫的步驟

    springboot 啟動時初始化數(shù)據(jù)庫的步驟

    這篇文章主要介紹了springboot 啟動時初始化數(shù)據(jù)庫的步驟,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下
    2021-01-01
  • Java對象的內(nèi)存布局全流程

    Java對象的內(nèi)存布局全流程

    這篇文章主要介紹了Java對象的內(nèi)存布局全流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論