我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mybatis plus实体类中字段映射mysql中的json格式方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mybatis plus实体类中字段映射mysql中的json格式方式

mybatis plus实体类中字段映射mysql中的json格式

1.实体类中有个属性是其他对象

或者是List;在数据库中存储时使用的是mysql的json格式,此时可以用mybatis plus的一个注解


@TableField(typeHandler = JacksonTypeHandler.class) 

在这里插入图片描述


@TableField(typeHandler = JacksonTypeHandler.class)

这样在存入是就可以把对象自动转换为json格式,

2.那么取出时怎么进行映射呢,有分为两种情况

  • a:当没有使用到xml时:

在这里插入图片描述


@Data
@Accessors(chain = true)
@TableName(value = "wx_user",autoResultMap = true)
  • b:当使用了xml文件时:

mybatis-plus 实体 json 处理

本文总共三个步骤

  • 1、在数据库表定义JSON字段;
  • 2、在实体类加上@TableName(autoResultMap = true)、在JSON字段映射的属性加上@TableField(typeHandler = FastjsonTypeHandler.class);
  • 3、建一些业务代码进行测试;

在数据库表定义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\"}]');

在实体类加上@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;
    }
}

建一些业务代码进行测试


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<>());
    }
}

运行结果:

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mybatis plus实体类中字段映射mysql中的json格式方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何解决mybatis-plus实体类中出现非数据库映射字段的问题

本篇内容主要讲解“如何解决mybatis-plus实体类中出现非数据库映射字段”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决mybatis-plus实体类中出现非数据库映射字段”吧!在使
2023-06-07

MySQL中查询json格式的字段实例详解

工作开发过程遇到一个需求:需要动态存储客户的姓名、手机号码、身份证、证件类型,意思是可能前端会传一个人或二个人或者三个人的信息是动态的不固定人数的四个字段(姓名、手机号码、身份证、证件类型)。 前端页面如下:我是使用List来接收前端传过来
2022-05-14

MyBatis Xml映射文件中的字符串替换方式是什么

这篇文章将为大家详细讲解有关MyBatis Xml映射文件中的字符串替换方式是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MyBatis Xml映射文件字符串替换字符串替换默认情况下,
2023-06-21

MySQL中varchar类型的字段默认值设置方式

目录mysql varchar字段默认值设置Mysql Varchar 类型为什么默认设置 255?Mysql5.6.xMysql5.7.x总结MySQL varchar字段默认值设置最近开始给项目设计数据库,遇到一个可能很多人都会遇到的
2023-10-19

mysql数据库中字段的注释和类型长度获取方式

本教程提供详细指南,介绍如何获取MySQL数据库字段的注释和类型长度。获取注释:使用EXPLAIN命令查询INFORMATION_SCHEMA.COLUMNS表使用第三方工具(例:phpMyAdmin)获取类型和长度:使用EXPLAIN命令查询INFORMATION_SCHEMA.COLUMNS表使用第三方工具(例:phpMyAdmin)例子:要获取users表中name字段的注释和长度,可以使用提供的查询。
mysql数据库中字段的注释和类型长度获取方式
2024-04-02

MySQL中字段类型为longtext的值导出后显示二进制串方式

目录mysql字段类型为longtext的值导出后显示二进制串使用MySQL的CAST()函数或者CONVERT()函数MySQL的基本语句及用法WHERE子句:条件查找UPDATE子句:数据更新DELETE子句:删除数据LINK子句:元字
2022-07-05

编程热搜

目录