mybatis-plus读取JSON类型并处理JSON中数据

mybatis-plus读取JSON类型

本文总共三个步骤:
1、在数据库表定义JSON字段;
2、在实体类加上@TableName(value = “extra_info”, autoResultMap = true)、在JSON字段映射的属性加上
@TableField(typeHandler = JacksonTypeHandler.class);

@TableField(typeHandler = ObjectAndJsonHandler.class);
3、建一些业务代码进行测试;

在数据库表定义JSON字段

DROP TABLE IF EXISTS `extra_info`;
CREATE TABLE `extra_info`  (
  `id` int(0) NOT NULL AUTO_INCREMENT,
  `extra_json` json NULL,
  `extra_object` json NULL,
  `extra_list` json NULL,
  `extra_array` json NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

INSERT INTO `extra_info` VALUES (1, '{\"id\": 6, \"name\": \"7\"}', '{\"id\": 1, \"name\": \"2\"}', '[{\"id\": 1, \"name\": \"2\"}, {\"id\": 2, \"name\": \"3\"}]', '[{\"id\": 1, \"name\": \"2\"}, {\"id\": 4, \"name\": \"5\"}]');

实体类处理

在实体类加上@TableName(value = "extra_info", autoResultMap = true)、在JSON字段映射的属性加上@TableField(typeHandler = JacksonTypeHandler.class),@TableField(typeHandler = ObjectAndJsonHandler.class) JacksonTypeHandler为mybatisplus自带,ObjectAndJsonHandler自定义;

ExtraInfo,ExtraNode

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.JacksonTypeHandler;
import com.util.ObjectAndJsonHandler;
import lombok.Data;

import java.io.Serializable;
import java.util.List;

@Data
@TableName(value = "extra_info", autoResultMap = true)
public class ExtraInfo implements Serializable {
   

    @TableId(type = IdType.AUTO)
    private Integer id;

    @TableField(typeHandler = JacksonTypeHandler.class)
    private ExtraNode extraObject;

    @TableField(typeHandler = FastjsonTypeHandler.class)
    private JSONObject extraJson;

    @TableField(typeHandler = ObjectAndJsonHandler.class)
    private List<ExtraNode> extraList;

    @TableField(typeHandler = JacksonTypeHandler
  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Mybatis-plus支持读取json类型数据,方法如下: 1. 首先,在数据创建一个json类型的字段,如下所示: CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, `address` varchar(255) DEFAULT NULL, `info` json DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 2. 在Java实体类,为info字段添加注解@JSONField,如下所示: public class User { private Long id; private String name; private String address; @JSONField(serializeUsing = JSONObjectSerializer.class, deserializeUsing = JSONObjectDeserializer.class) private JSONObject info; // 省略getter和setter方法 } 3. 在Mybatis-plus的mapper接口,使用@Results和@Result注解映射json字段,如下所示: @Results(id = "userResultMap", value = { @Result(property = "id", column = "id", id = true), @Result(property = "name", column = "name"), @Result(property = "address", column = "address"), @Result(property = "info", column = "info", javaType = JSONObject.class, typeHandler = JSONTypeHandler.class), }) public interface UserMapper extends BaseMapper<User> {} 4. 在配置文件,配置typeHandlersPackage为org.apache.ibatis.type,如下所示: mybatis-plus: configuration: map-underscore-to-camel-case: true log-impl: org.apache.ibatis.logging.stdout.StdOutImpl type-handlers-package: org.apache.ibatis.type 5. 最后,就可以在mapper接口使用Mybatis-plus提供的方法读取json类型数据了,如下所示: User user = userMapper.selectOne(Wrappers.<User>lambdaQuery().eq(User::getId, 1L)); JSONObject info = user.getInfo(); 以上就是Mybatis-plus读取json类型数据的方法实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值