MybatisPlus將自定義的sql列表查詢返回改為分頁(yè)查詢
問題描述
在開發(fā)過程中在 mapper.xml 文件中自定義了一個(gè) sql 查詢列表的 select 語(yǔ)句,但是由于前端需要的是分頁(yè)數(shù)據(jù),需要在后端將列表查詢改成分頁(yè)查詢
修改前
1. 查詢數(shù)據(jù)類型
@Data
public class OppRelMoveWrapper implements BaseData {
/**
* ID
*/
private Long id;
/**
* 商機(jī)ID
*/
private Long oppId;
/**
* RELATIONSHIP
*/
private String relationship;
/**
* 關(guān)系評(píng)價(jià)附件
*/
private String attachmentRel;
/**
* CHIEF_RECORD
*/
private String chiefRecord;
/**
* 首席代表動(dòng)態(tài)記錄附件
*/
private String attachmentChief;
/**
* ORDINARY_RECORD
*/
private String ordinaryRecord;
/**
* 普通動(dòng)態(tài)記錄附件
*/
private String attachmentOrdinary;
/**
* 錄入人
*/
private Long createStaff;
/**
* 錄入時(shí)間
*/
private Date createDate;
/**
* 更新時(shí)間
*/
private Date updateDate;
}
2. mapper定義
@Mapper
public interface OppRelationshipInfoMoveMapper extends BaseMapper<OppRelationshipInfoMove> {
List<OppRelMoveWrapper> queryMoveClientList(@Param("query") OppRelMoveQuery query);
}
3. xml文件定義
該語(yǔ)句查詢的是一個(gè)返回?cái)?shù)據(jù)類型為OppRelationshipInfoMoveMap的列表
<resultMap type="com.wrapper.OppRelMoveWrapper"
id="OppRelationshipInfoMoveMap">
<result property="id" column="ID" jdbcType="INTEGER"/>
<result property="oppId" column="OPP_ID" jdbcType="INTEGER"/>
<result property="relationship" column="RELATIONSHIP" jdbcType="VARCHAR"/>
<result property="attachmentRel" column="attachment_rel" jdbcType="VARCHAR"/>
<result property="chiefRecord" column="CHIEF_RECORD" jdbcType="VARCHAR"/>
<result property="attachmentChief" column="attachment_chief" jdbcType="VARCHAR"/>
<result property="ordinaryRecord" column="ORDINARY_RECORD" jdbcType="VARCHAR"/>
<result property="attachmentOrdinary" column="attachment_ordinary" jdbcType="VARCHAR"/>
<result property="createStaff" column="CREATE_STAFF" jdbcType="INTEGER"/>
<result property="createDate" column="CREATE_DATE" jdbcType="TIMESTAMP"/>
<result property="updateDate" column="UPDATE_DATE" jdbcType="TIMESTAMP"/>
</resultMap>
<select id="queryMoveClientList" resultMap="OppRelationshipInfoMoveMap">
SELECT
ID,
OPP_ID,
RELATIONSHIP,
attachment_rel,
CHIEF_RECORD,
attachment_chief,
ORDINARY_RECORD,
attachment_ordinary,
CREATE_STAFF,
CREATE_DATE,
UPDATE_DATE
FROM opp_relationship_info_move
WHERE 1=1
<if test="query.createDate != null and query.createDate != ''">
AND DATE_FORMAT(CREATE_DATE, '%Y-%m-%d') = #{query.createDate}
</if>
<if test="query.updateDate != null and query.updateDate != ''">
AND DATE_FORMAT(UPDATE_DATE, '%Y-%m-%d') = #{query.updateDate}
</if>
<if test="query.oppId != null and query.oppId != ''">
AND OPP_ID = #{query.oppId}
</if>
ORDER BY CREATE_DATE DESC
</select>
4. 函數(shù)使用
List<OppRelMoveWrapper> moveWrapperList = oppRelationshipInfoMoveMapper.queryMoveClientList(query);
修改后
修改成分頁(yè)查詢比較簡(jiǎn)單,直接將 mapper 的查詢方法修改即可
1. 修改mapper
將函數(shù)返回的數(shù)據(jù)改成 Page類型
@Mapper
public interface OppRelationshipInfoMoveMapper extends BaseMapper<OppRelationshipInfoMove> {
Page<OppRelMoveWrapper> queryMoveClientList(Page<Object> page, @Param("query") OppRelMoveQuery query);
}
2. 函數(shù)使用
注意: 構(gòu)造Page時(shí)里面的 pageNum 和 pageSize 一定要存在?。。?否則獲得的 Page 中的 records 為空?。?!
Page<OppRelMoveWrapper> moveWrapperPage = oppRelationshipInfoMoveMapper.queryMoveClientList(
new Page(query.getPage(), query.getPageSize(), true), query);
結(jié)語(yǔ)
很香的一個(gè)方法,使我的列表查詢變成分頁(yè)查詢。
到此這篇關(guān)于MybatisPlus將自定義的sql列表查詢返回改為分頁(yè)查詢的文章就介紹到這了,更多相關(guān)MybatisPlus自定義sql列表查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MyBatis-Plus實(shí)現(xiàn)對(duì)查詢結(jié)果進(jìn)行分頁(yè)的基本步驟
- MybatisPlus多表查詢及分頁(yè)查詢完整代碼
- MyBatis分頁(yè)查詢返回list的時(shí)候出現(xiàn)null的問題
- mybatis-plus分頁(yè)查詢的實(shí)現(xiàn)實(shí)例
- MyBatis分頁(yè)查詢與特殊字符處理方式
- Mybatis實(shí)現(xiàn)分頁(yè)查詢的詳細(xì)流程
- mybatis-plus分頁(yè)查詢?nèi)N方法小結(jié)
- Java中Mybatis分頁(yè)查詢的四種傳參方式
- Mybatis分頁(yè)查詢主從表的實(shí)現(xiàn)示例
相關(guān)文章
Java Collections集合繼承結(jié)構(gòu)圖_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java Collections集合繼承結(jié)構(gòu)圖_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理,需要的朋友可以參考下2017-04-04
詳解Java編程的Observer觀察者設(shè)計(jì)模式
這篇文章主要介紹了Java編程的Observer觀察者設(shè)計(jì)模式,觀察者模式定義了一個(gè)一對(duì)多的依賴關(guān)系,讓一個(gè)或多個(gè)觀察者對(duì)象監(jiān)察一個(gè)主題對(duì)象,需要的朋友可以參考下2016-01-01
Spring使用Configuration注解管理bean的方式詳解
在Spring的世界里,Configuration注解就像是一位細(xì)心的園丁,它的主要職責(zé)是在這個(gè)繁花似錦的園子里,幫助我們聲明和管理各種各樣的bean,本文給大家介紹了在Spring中如何優(yōu)雅地管理你的bean,需要的朋友可以參考下2024-05-05

