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

MyBatisPlus深入探究映射匹配的兼容性

 更新時間:2022年08月18日 14:56:49   作者:十八歲討厭編程  
在最近的工作中,碰到一個比較復(fù)雜的返回結(jié)果,發(fā)現(xiàn)簡單映射已經(jīng)解決不了這個問題了,只好去求助百度,學習mybatis映射匹配應(yīng)該怎么寫,將學習筆記結(jié)合工作碰到的問題寫下本文,供自身查漏補缺,同時已被不時之需

映射匹配兼容性

前面我們已經(jīng)能從表中查詢出數(shù)據(jù),并將數(shù)據(jù)封裝到模型類中,這整個過程涉及到一張表和一個模型類:

之所以數(shù)據(jù)能夠成功的從表中獲取并封裝到模型對象中,原因是表的字段列名和模型類的屬性名一樣。

那么問題就來了:

  • 問題1:表字段與編碼屬性設(shè)計不同步

當表的列名和模型類的屬性名發(fā)生不一致,就會導(dǎo)致數(shù)據(jù)封裝不到模型對象,這個時候就需要其中一方做出修改,那如果前提是兩邊都不能改又該如何解決?

MP給我們提供了一個注解@TableField,使用該注解可以實現(xiàn)模型類屬性名和表的列名之間的映射關(guān)系

  • 問題2:編碼中添加了數(shù)據(jù)庫中未定義的屬性

當模型類中多了一個數(shù)據(jù)庫表不存在的字段,就會導(dǎo)致生成的sql語句中在select的時候查詢了數(shù)據(jù)庫不存在的字段,程序運行就會報錯,錯誤信息為:

Unknown column ‘多出來的字段名稱’ in ‘field list’

具體的解決方案用到的還是@TableField注解,它有一個屬性叫exist,設(shè)置該字段是否在數(shù)據(jù)庫表中存在,如果設(shè)置為false則不存在,生成sql語句查詢的時候,就不會再查詢該字段了。

  • 問題3:采用默認查詢開放了更多的字段查看權(quán)限

查詢表中所有的列的數(shù)據(jù),就可能把一些敏感數(shù)據(jù)查詢到返回給前端,這個時候我們就需要限制哪些字段默認不要進行查詢。解決方案是@TableField注解的一個屬性叫select,該屬性設(shè)置默認是否需要查詢該字段的值,true(默認值)表示默認查詢該字段,false表示默認不查詢該字段。

知識點@TableField

名稱@TableField
類型屬性注解
位置模型類屬性定義上方
作用設(shè)置當前屬性對應(yīng)的數(shù)據(jù)庫表中的字段關(guān)系
相關(guān)屬性value(默認):設(shè)置數(shù)據(jù)庫表字段名稱
exist:設(shè)置屬性在數(shù)據(jù)庫表字段中是否存在,默認為true,此屬性不能與value合并使用
select:設(shè)置屬性是否參與查詢,此屬性與select()映射配置不沖突
  • 問題4:表名與編碼開發(fā)設(shè)計不同步

該問題主要是表的名稱和模型類的名稱不一致,導(dǎo)致查詢失敗,這個時候通常會報如下錯誤信息:

Table ‘databaseName.tableNaem’ doesn’t exist,翻譯過來就是數(shù)據(jù)庫中的表不存在。

解決方案是使用MP提供的另外一個注解@TableName來設(shè)置表與模型類之間的對應(yīng)關(guān)系。

知識點@TableName

名稱@TableName
類型類注解
位置模型類定義上方
作用設(shè)置當前類對應(yīng)于數(shù)據(jù)庫表關(guān)系
相關(guān)屬性value(默認):設(shè)置數(shù)據(jù)庫表名稱

代碼演示

接下來我們使用案例的方式把剛才的知識演示下:

步驟1:修改數(shù)據(jù)庫表user為tbl_user

直接查詢會報錯,原因是MP默認情況下會使用模型類的類名首字母小寫當表名使用。

步驟2:模型類添加@TableName注解

@Data
@TableName("tbl_user")
public class User {
    private Long id;
    private String name;
    private String password;
    private Integer age;
    private String tel;
}

步驟3:將字段password修改成pwd

直接查詢會報錯,原因是MP默認情況下會使用模型類的屬性名當做表的列名使用

步驟4:使用@TableField映射關(guān)系

@Data
@TableName("tbl_user")
public class User {
    private Long id;
    private String name;
    @TableField(value="pwd")
    private String password;
    private Integer age;
    private String tel;
}

步驟5:添加一個數(shù)據(jù)庫表不存在的字段

@Data
@TableName("tbl_user")
public class User {
    private Long id;
    private String name;
    @TableField(value="pwd")
    private String password;
    private Integer age;
    private String tel;
    private Integer online;
}

直接查詢會報錯,原因是MP默認情況下會查詢模型類的所有屬性對應(yīng)的數(shù)據(jù)庫表的列,而online不存在

步驟6:使用@TableField排除字段

@Data
@TableName("tbl_user")
public class User {
    private Long id;
    private String name;
    @TableField(value="pwd")
    private String password;
    private Integer age;
    private String tel;
    @TableField(exist=false)
    private Integer online;
}

步驟7:查詢時將pwd隱藏

@Data
@TableName("tbl_user")
public class User {
    private Long id;
    private String name;
    @TableField(value="pwd",select=false)
    private String password;
    private Integer age;
    private String tel;
    @TableField(exist=false)
    private Integer online;
}

到此這篇關(guān)于MyBatisPlus深入探究映射匹配的兼容性的文章就介紹到這了,更多相關(guān)MyBatis映射匹配內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java中javamail收發(fā)郵件實現(xiàn)方法

    java中javamail收發(fā)郵件實現(xiàn)方法

    這篇文章主要為大家詳細介紹了java中javamail收發(fā)郵件實現(xiàn)方法,實例分析了javamail的使用方法與相關(guān)注意事項,非常具有實用價值,感興趣的小伙伴們可以參考一下
    2016-02-02
  • 關(guān)于jdk環(huán)境變量的配置方式解讀

    關(guān)于jdk環(huán)境變量的配置方式解讀

    這篇文章主要介紹了關(guān)于jdk環(huán)境變量的配置方式解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 關(guān)于MyBatis中映射對象關(guān)系的舉例

    關(guān)于MyBatis中映射對象關(guān)系的舉例

    這篇文章主要介紹了關(guān)于MyBatis中映射對象關(guān)系的舉例,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • java foreach循環(huán)為什么不能賦值的講解

    java foreach循環(huán)為什么不能賦值的講解

    這篇文章主要介紹了java foreach循環(huán)為什么不能賦值的講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 詳解Java中的延時隊列 DelayQueue

    詳解Java中的延時隊列 DelayQueue

    這篇文章主要介紹了Java中延時隊列 DelayQueue的相關(guān)資料,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-12-12
  • java中aop實現(xiàn)接口訪問頻率限制

    java中aop實現(xiàn)接口訪問頻率限制

    本文主要介紹了java中aop實現(xiàn)接口訪問頻率限制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • Java?LockSupport常用方法的源碼分析

    Java?LockSupport常用方法的源碼分析

    這篇文章主要為大家詳細介紹了Java?LockSupport類中的方法和部分源碼,以及面試常問到的一個小問題,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-02-02
  • IntelliJ IDEA中打開拼寫檢查與忽略提示曲線的方法

    IntelliJ IDEA中打開拼寫檢查與忽略提示曲線的方法

    今天小編就為大家分享一篇關(guān)于IntelliJ IDEA中打開拼寫檢查與忽略提示曲線的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • sprintboot使用spring-security包,緩存內(nèi)存與redis共存方式

    sprintboot使用spring-security包,緩存內(nèi)存與redis共存方式

    這篇文章主要介紹了sprintboot使用spring-security包,緩存內(nèi)存與redis共存方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java設(shè)計模式之裝飾者模式詳解和代碼實例

    Java設(shè)計模式之裝飾者模式詳解和代碼實例

    這篇文章主要介紹了Java設(shè)計模式之裝飾者模式詳解和代碼實例,Decorator模式(別名Wrapper):動態(tài)將職責附加到對象上,若要擴展功能,裝飾者提供了比繼承更具彈性的代替方案,需要的朋友可以參考下
    2014-09-09

最新評論