MyBatis通过TypeHandler自动编解码对象的Json属性

本文介绍了如何在MyBatis中通过自定义TypeHandler实现对象Json属性的自动序列化和反序列化,以适配MySQL的json列。详细步骤包括整合MyBatis、定义表结构和模型对象、配置TypeHandler以及进行测试,确保在数据库存取过程中正确编解码Json数据。
摘要由CSDN通过智能技术生成

mysql从5.7.版本开始支持json列。它本质上仍然是一个字符串,比起直接用varchar来说,它有专门对于json的的检索,修改方法。更加的灵活。

在jdbc规范中,还没json类型的定义。所以对象一般都是用String属性,映射数据库的json列。在存储和读取的时候,需要自己完成json的序列化和反序列化。

在使用MyBatis的框架,可以通过定义TypeHandler来自动完成Json属性的序列化和反序列化。

演示一个Demo

这里使用GsonJsonElement作为对象的Json属性对象。我觉得它比较灵活,可以在JsonObjectJsonArray中随意转换。

整合MyBatis

… 略

表结构 & 模型对象

表结构

CREATE TABLE `website` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',
  `name` varchar(255) NOT NULL COMMENT '网站名称',
  `properties` json DEFAULT NULL COMMENT '网站属性,这是一个Json列',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

模型对象

import com.google.gson.JsonElement;

public class WebSite {
   
	// 网站id
	private Integer id;
	// 网站名称
	private String name;
	// 网站属性,json
	private JsonElement properties;
	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;
	}
	public JsonElement getProperties() {
   
		
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值