实战!Mybatis-plus操作json字段实战

简介: 本文主要介绍基于mybatis-plus的json字段实战,介绍json字段的查询操作,希望对您有帮助

后端动态列设计与实现三部曲,这是最后一步,使用java语言,结合mybatis-plus神技操作json字段。


简单介绍下mybatis-plus,大厂中mybatis使用的非常多,而mybatis-plus是基于mybatis做了扩展,进一步增强,在不影响数据存储的情况下,简化操作方式。有兴趣的朋友可以去官网了解:https://www.baomidou.com/

1、架构图

image.png

2、功能

image.png

3、表结构

DROPTABLE IF EXISTS user;CREATETABLE user(  id BIGINT(20)NOTNULL COMMENT '主键ID',  name VARCHAR(30)NULL DEFAULT NULL COMMENT '姓名',  age INT(11)NULL DEFAULT NULL COMMENT '年龄',  email VARCHAR(50)NULL DEFAULT NULL COMMENT '邮箱',  wallet VARCHAR(3000)NULL DEFAULT NULL COMMENT '钱包',  other_info VARCHAR(3000)NULL DEFAULT NULL COMMENT '其他信息',  PRIMARY KEY (id));INSERTINTO user (id, name, age, email, wallet, other_info)VALUES(1,'Jone',18,'test1@baomidou.com','{"name": "支付宝钱包","currencyList": [{"type": "USD","amount": 999.19},{"type": "RMB","amount": 1000.19}]}','{"sex": "男","city": "南昌"}'),(2,'Jack',20,'test2@baomidou.com','{"name": "微信钱包","currencyList": [{"type": "USD","amount": 888.18},{"type": "RMB","amount": 1000.18}]}','{"sex": "男","city": "青岛"}');

4、实体定义

packagecom.baomidou.mybatisplus.samples.typehandler.entity;
importcom.baomidou.mybatisplus.annotation.TableField;
importcom.baomidou.mybatisplus.annotation.TableName;
importcom.baomidou.mybatisplus.extension.handlers.FastjsonTypeHandler;
importcom.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
importlombok.Data;
importlombok.experimental.Accessors;
/**用户实体对应表 user* @author hubin* @since 2018-08-11*/@Data@Accessors(chain=true)
@TableName(autoResultMap=true)
publicclassUser {
privateLongid;
privateStringname;
privateIntegerage;
privateStringemail;
/*** 注意!!必须开启映射注解** @TableName(autoResultMap = true)** 以下两种类型处理器,二选一 也可以同时存在** 注意!!选择对应的 JSON 处理器也必须存在对应依赖包*/@TableField(typeHandler=JacksonTypeHandler.class)
privateWalletwallet;
@TableField(typeHandler=FastjsonTypeHandler.class)
privateOtherInfootherInfo;
}
packagecom.baomidou.mybatisplus.samples.typehandler.entity;
importjava.util.List;
importlombok.Data;
/*** 钱包*/@DatapublicclassWallet {
/*** 名称*/privateStringname;
/*** 各种货币*/privateList<Currency>currencyList;
}
packagecom.baomidou.mybatisplus.samples.typehandler.entity;
importlombok.Data;
/*** 货币*/@DatapublicclassCurrency {
/*** 类型: 人民币 RMB , 美元 USD*/privateStringtype;
/*** 金额*/privateDoubleamount;
}
packagecom.baomidou.mybatisplus.samples.typehandler.entity;
importlombok.Data;
/*** 其他信息*/@DatapublicclassOtherInfo {
/*** 性别*/privateStringsex;
/*** 居住城市*/privateStringcity;
}

5、Dao定义

packagecom.baomidou.mybatisplus.samples.typehandler.mapper;
importcom.baomidou.mybatisplus.core.mapper.BaseMapper;
importcom.baomidou.mybatisplus.samples.typehandler.entity.User;
/*** <p>* MP 支持不需要 UserMapper.xml 这个模块演示内置 CRUD 咱们就不要 XML 部分了* </p>** @author hubin* @since 2018-08-11*/publicinterfaceUserMapperextendsBaseMapper<User> {
}

6、类型转换器

packagecom.baomidou.mybatisplus.samples.typehandler.config;
importcom.baomidou.mybatisplus.extension.handlers.GsonTypeHandler;
importcom.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
importcom.fasterxml.jackson.databind.ObjectMapper;
importcom.google.gson.Gson;
importorg.springframework.boot.CommandLineRunner;
importorg.springframework.stereotype.Component;
/*** @author miemie* @since 2019-11-28*/@ComponentpublicclassMpJsonConfigimplementsCommandLineRunner {
/*** 可以set进去自己的*/@Overridepublicvoidrun(String... args) throwsException {
JacksonTypeHandler.setObjectMapper(newObjectMapper());
GsonTypeHandler.setGson(newGson());
    }
}

7、测试

packagecom.baomidou.mybatisplus.samples.typehandler;
importjavax.annotation.Resource;
importorg.junit.Test;
importorg.junit.runner.RunWith;
importorg.springframework.boot.test.context.SpringBootTest;
importorg.springframework.test.context.junit4.SpringRunner;
importcom.baomidou.mybatisplus.samples.typehandler.entity.User;
importcom.baomidou.mybatisplus.samples.typehandler.mapper.UserMapper;
/*** <p>* 内置 类型处理器 演示* </p>** @author hubin* @since 2018-08-11*/@RunWith(SpringRunner.class)
@SpringBootTestpublicclassSampleTest {
@ResourceprivateUserMapperuserMapper;
/*** 自定义类型处理器演示参考 mybatis-plus-sample-deluxe 模块*/@Testpublicvoidtest() {
UserJone=userMapper.selectById(1);
System.out.println(Jone);
System.err.println(Jone.getName());
UserJack=userMapper.selectById(1);
System.err.println(Jack.getName());
    }
}

结果如下:

2020-11-2212:46:58.164INFO3168--- [           main] c.b.m.samples.typehandler.SampleTest     : StartedSampleTestin4.125seconds (JVMrunningfor5.707)
2020-11-2212:46:58.477DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>Preparing: SELECTid,name,age,email,wallet,other_infoFROMuserWHEREid=?2020-11-2212:46:58.509DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>Parameters: 1(Integer)
2020-11-2212:46:58.713DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : <==Total: 1User(id=1, name=Jone, age=18, email=test1@baomidou.com, wallet=Wallet(name=支付宝钱包, currencyList=[Currency(type=USD, amount=999.19), Currency(type=RMB, amount=1000.19)]), otherInfo=OtherInfo(sex=, city=南昌))
2020-11-2212:46:58.715DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>Preparing: SELECTid,name,age,email,wallet,other_infoFROMuserWHEREid=?2020-11-2212:46:58.715DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>Parameters: 2(Integer)
2020-11-2212:46:58.716DEBUG3168--- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : <==Total: 1User(id=2, name=Jack, age=20, email=test2@baomidou.com, wallet=Wallet(name=微信钱包, currencyList=[Currency(type=USD, amount=888.18), Currency(type=RMB, amount=1000.18)]), otherInfo=OtherInfo(sex=, city=青岛))
2020-11-2212:46:58.736INFO3168--- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1-Shutdowninitiated...
2020-11-2212:46:58.747INFO3168--- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1-Shutdowncompleted.

总结,使用mybatis-plus可以提高应用程序操作数据库的效率,让开发人员专注于业务逻辑实现。在使用mybatis-plus操作json字段的要点主要有:


1、在需要处理的字段上使用@TableField(typeHandler = JacksonTypeHandler.class),同时实体开启@TableName(autoResultMap = true)


2、注册工具类,MpJsonConfig.


mybatis-plus 还有许多很好用的功能,感兴趣的朋友可以自己去官网上下看,也可能从github或者gitee上拉取最新代码,了解它的工作原理,结合自己的业务做一些增强。欢迎留言交流。

目录
相关文章
|
4月前
|
Java 数据库连接 数据库
mybatis查询数据,返回的对象少了一个字段
mybatis查询数据,返回的对象少了一个字段
296 8
|
2月前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
2月前
|
前端开发 开发者
如何理解 package.json 中的 proxy 字段?
`package.json` 中的 `proxy` 字段用于配置代理服务器,帮助前端开发中解决跨域问题及模拟后端响应。其基本概念、使用场景及配置方法将在本文中详细探讨,助力开发者高效调试与测试。
75 4
|
2月前
|
JSON Java 数据格式
springboot中表字段映射中设置JSON格式字段映射
springboot中表字段映射中设置JSON格式字段映射
166 1
|
7月前
|
XML Java 数据库连接
【MyBatis】MyBatis操作数据库(一)
【MyBatis】MyBatis操作数据库(一)
62 1
|
7月前
|
SQL 存储 Java
基于MyBatis的增删改查操作
基于MyBatis的增删改查操作
49 1
|
3月前
|
SQL Java 数据库连接
mybatis如何仅仅查询某个表的几个字段
【10月更文挑战第19天】mybatis如何仅仅查询某个表的几个字段
101 1
|
3月前
|
JSON API 数据格式
postman如何发送json请求其中file字段是一个图片
postman如何发送json请求其中file字段是一个图片
174 4
|
4月前
|
JSON 数据库 数据格式
数据库表如果有json字段,该怎么更新
数据库表如果有json字段,该怎么更新
|
6月前
|
Java 数据库连接 数据库
mybatis plus 更新值为null的字段
mybatis plus 更新值为null的字段
71 7