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

mybatis plus實(shí)體類中字段映射mysql中的json格式方式

 更新時間:2021年08月31日 11:16:37   作者:小明哥帶你飛  
這篇文章主要介紹了mybatis plus實(shí)體類中字段映射mysql中的json格式方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis plus實(shí)體類中字段映射mysql中的json格式

1.實(shí)體類中有個屬性是其他對象

或者是List;在數(shù)據(jù)庫中存儲時使用的是mysql的json格式,此時可以用mybatis plus的一個注解

@TableField(typeHandler = JacksonTypeHandler.class) 

在這里插入圖片描述

@TableField(typeHandler = JacksonTypeHandler.class)

這樣在存入是就可以把對象自動轉(zhuǎn)換為json格式,

2.那么取出時怎么進(jìn)行映射呢,有分為兩種情況

  • a:當(dāng)沒有使用到xml時:

在這里插入圖片描述

@Data
@Accessors(chain = true)
@TableName(value = "wx_user",autoResultMap = true)
  • b:當(dāng)使用了xml文件時:

mybatis-plus 實(shí)體 json 處理

本文總共三個步驟

  • 1、在數(shù)據(jù)庫表定義JSON字段;
  • 2、在實(shí)體類加上@TableName(autoResultMap = true)、在JSON字段映射的屬性加上@TableField(typeHandler = FastjsonTypeHandler.class);
  • 3、建一些業(yè)務(wù)代碼進(jìn)行測試;

在數(shù)據(jù)庫表定義JSON字段

CREATE TABLE `extra_info`  (
  `id` int(10) NOT NULL AUTO_INCREMENT PRIMARY KEY,
  `extra_object` json NULL,
  `extra_list` json NULL,
  `extra_array` json NULL
); 
INSERT INTO `extra_info` VALUES (1, '{\"id\": 1, \"name\": \"2\"}', '[{\"id\": 1, \"name\": \"2\"}]', '[{\"id\": 1, \"name\": \"2\"}]');

在實(shí)體類加上@TableName(autoResultMap = true)、在JSON字段映射的屬性加上@TableField(typeHandler = FastjsonTypeHandler.class)

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.handlers.FastjsonTypeHandler; 
import java.io.Serializable;
import java.util.List;
 
@TableName(autoResultMap = true)
public class ExtraInfo implements Serializable {
 
    @TableId(type = IdType.AUTO)
    private Integer id;
 
    @TableField(typeHandler = FastjsonTypeHandler.class)
    private ExtraNode extraObject;
 
    @TableField(typeHandler = FastjsonTypeHandler.class)
    private List<ExtraNode> extraList;
 
    @TableField(typeHandler = FastjsonTypeHandler.class)
    private ExtraNode[] extraArray;
 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    public ExtraNode getExtraObject() {
        return extraObject;
    }
 
    public void setExtraObject(ExtraNode extraObject) {
        this.extraObject = extraObject;
    }
 
    public List<ExtraNode> getExtraList() {
        return extraList;
    }
 
    public void setExtraList(List<ExtraNode> extraList) {
        this.extraList = extraList;
    }
 
    public ExtraNode[] getExtraArray() {
        return extraArray;
    }
 
    public void setExtraArray(ExtraNode[] extraArray) {
        this.extraArray = extraArray;
    }
}

建一些業(yè)務(wù)代碼進(jìn)行測試

import java.io.Serializable; 
public class ExtraNode implements Serializable { 
    private Integer id;
    private String name; 
    public Integer getId() {
        return id;
    }
 
    public void setId(Integer id) {
        this.id = id;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
}
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.springframework.stereotype.Repository;
 
@Repository
public interface ExtraInfoMapper extends BaseMapper<ExtraInfo> {
}
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; 
import java.util.List;
 
@RestController
@RequestMapping("/test")
public class TestController { 
    @Autowired
    private ExtraInfoMapper extraInfoMapper;
 
    @GetMapping
    public List<ExtraInfo> listAll() {
        return this.extraInfoMapper.selectList(new LambdaQueryWrapper<>());
    }
}

運(yùn)行結(jié)果:

[
  {
    "id": 1,
    "extraObject": { "id": 1, "name": "2" },
    "extraList": [
      { "name": "2", "id": 1 }
    ],
    "extraArray": [
      { "id": 1, "name": "2" }
    ]
  }
]

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

相關(guān)文章

  • 實(shí)現(xiàn) Java 本地緩存的方法解析

    實(shí)現(xiàn) Java 本地緩存的方法解析

    這篇文章主要介紹了實(shí)現(xiàn) Java 本地緩存的方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • Maven2 plugin開發(fā)教程詳解

    Maven2 plugin開發(fā)教程詳解

    這篇文章主要為大家詳細(xì)介紹了Maven2 plugin的開發(fā)教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Java入門絆腳石之Override和Overload的區(qū)別詳解

    Java入門絆腳石之Override和Overload的區(qū)別詳解

    重寫是子類對父類的允許訪問的方法的實(shí)現(xiàn)過程進(jìn)行重新編寫, 返回值和形參都不能改變。即外殼不變,核心重寫!重寫的好處在于子類可以根據(jù)需要,定義特定于自己的行為。重載是在一個類里面,方法名字相同,而參數(shù)不同。返回類型可以相同也可以不同
    2021-10-10
  • 深入解析Java的Spring框架中bean的依賴注入

    深入解析Java的Spring框架中bean的依賴注入

    這篇文章主要介紹了Java的Spring框架中bean的依賴注入,講解了以構(gòu)造函數(shù)為基礎(chǔ)的依賴注入和基于setter方法的依賴注入的方式,需要的朋友可以參考下
    2015-12-12
  • SpringSecurity認(rèn)證流程詳解

    SpringSecurity認(rèn)證流程詳解

    這篇文章主要介紹了SpringSecurity認(rèn)證流程詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • springboot2.3 整合mybatis-plus 高級功能及用法詳解

    springboot2.3 整合mybatis-plus 高級功能及用法詳解

    這篇文章主要介紹了springboot2.3 整合mybatis-plus 高級功能,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • java使用電腦攝像頭識別二維碼

    java使用電腦攝像頭識別二維碼

    這篇文章主要為大家詳細(xì)介紹了java使用電腦攝像頭識別二維碼,從攝像頭獲取圖像,再根據(jù)圖片解析出二維碼信息,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • Spring Boot 整合 Mockito提升Java單元測試的高效實(shí)踐案例

    Spring Boot 整合 Mockito提升Java單元測試的高效實(shí)踐案例

    Mockito與Spring Boot的整合為Java開發(fā)者提供了一套完整的解決方案,使得單元測試更為精準(zhǔn)、高效,從而確保了代碼質(zhì)量、降低了維護(hù)成本,并促進(jìn)了項(xiàng)目的持續(xù)集成與交付,感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • SpringMVC解析post請求參數(shù)詳解

    SpringMVC解析post請求參數(shù)詳解

    今天小編就為大家分享一篇解決SpringMVC接收不到ajaxPOST參數(shù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-08-08
  • 解決SpringBoot web項(xiàng)目啟動后立即關(guān)閉的問題

    解決SpringBoot web項(xiàng)目啟動后立即關(guān)閉的問題

    這篇文章主要介紹了解決SpringBoot web項(xiàng)目啟動后立即關(guān)閉的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08

最新評論