溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

發(fā)布時間:2022-03-10 14:18:50 來源:億速云 閱讀:741 作者:iii 欄目:開發(fā)技術(shù)

這篇“mybatis plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“mybatis plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法”文章吧。

關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段

java自帶 聲明該字段是 transient 的

    /**
     * 虛擬綁定流程當(dāng)前審批人對應(yīng)表字段
     */
    private transient  String status;

聲明該字段是 static 的

    /**
     * 虛擬綁定流程當(dāng)前審批人對應(yīng)表字段
     */
    private static  String status;

通過注解聲明該字段不是一個數(shù)據(jù)庫表里面的字段

    /**
     * 虛擬綁定流程當(dāng)前審批人對應(yīng)表字段
     */
    @TableField(exist = false)
    private  String status;

哪種業(yè)務(wù)場景用哪種方式呢?

如果想既支持序列化又不需要關(guān)聯(lián)數(shù)據(jù)庫字段 ,則用 @TableField;

如果只是不想關(guān)聯(lián)數(shù)據(jù)庫,則三種都可以使用;

項目中,由于導(dǎo)出excel 時候,數(shù)據(jù)必須序列化和反序列化,所以用 transient 確實能滿足排除非數(shù)據(jù)庫字段,但是也會導(dǎo)致數(shù)據(jù)導(dǎo)出時候為null,所以這種場景最好用@@TableField 

排除自定義字段不查詢

需求原因

由于數(shù)據(jù)庫表設(shè)計為一張為組表

一張為對應(yīng)組下的參數(shù)表

在查詢數(shù)據(jù)時想要在查詢組表的同時吧對應(yīng)組下的數(shù)據(jù)頁同時查出來

所以在組實體類下增加了一個對應(yīng)的參數(shù)來接受對應(yīng)的組數(shù)據(jù)

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

錯誤截圖

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

錯誤分析

根據(jù)查詢語句來看

條件查詢默認(rèn)把所有字段都查出來了

但由于自定義的字段在數(shù)據(jù)庫中不存在,所以報錯

嘗試

這里最大的問題就是如何把自定義字段排除掉,在網(wǎng)上搜了一圈,

最后才在Mybatis-plus的官方文檔里發(fā)現(xiàn)

@TableFiled有一個exist屬性,是用來定義字段是否為數(shù)據(jù)庫表字段的。。。。

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

于是把該屬性加上

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

重新運行

mybatis?plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法

以上就是關(guān)于“mybatis plus關(guān)聯(lián)數(shù)據(jù)庫排除不必要字段的方法”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI