mysql从5.7.版本开始支持json列。它本质上仍然是一个字符串,比起直接用varchar来说,它有专门对于json的的检索,修改方法。更加的灵活。
在jdbc规范中,还没json类型的定义。所以对象一般都是用String属性,映射数据库的json列。在存储和读取的时候,需要自己完成json的序列化和反序列化。
在使用MyBatis的框架,可以通过定义TypeHandler来自动完成Json属性的序列化和反序列化。
演示一个Demo
这里使用Gson的JsonElement作为对象的Json属性对象。我觉得它比较灵活,可以在JsonObject和JsonArray中随意转换。
整合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()

本文介绍了如何在MyBatis中通过自定义TypeHandler实现对象Json属性的自动序列化和反序列化,以适配MySQL的json列。详细步骤包括整合MyBatis、定义表结构和模型对象、配置TypeHandler以及进行测试,确保在数据库存取过程中正确编解码Json数据。
最低0.47元/天 解锁文章
1219

被折叠的 条评论
为什么被折叠?



