实战!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上拉取最新代码,了解它的工作原理,结合自己的业务做一些增强。欢迎留言交流。

目录
相关文章
|
Java 数据库连接 数据库
mybatis查询数据,返回的对象少了一个字段
mybatis查询数据,返回的对象少了一个字段
1054 9
|
8月前
|
数据采集 JSON 数据可视化
JSON数据解析实战:从嵌套结构到结构化表格
在信息爆炸的时代,从杂乱数据中提取精准知识图谱是数据侦探的挑战。本文以Google Scholar为例,解析嵌套JSON数据,提取文献信息并转换为结构化表格,通过Graphviz制作技术关系图谱,揭示文献间的隐秘联系。代码涵盖代理IP、请求头设置、JSON解析及可视化,提供完整实战案例。
536 4
JSON数据解析实战:从嵌套结构到结构化表格
|
10月前
|
SQL Java 数据库连接
Mybatis拦截器实现公共字段填充
通过使用MyBatis拦截器,可以实现对公共字段的自动填充,简化代码,提高开发效率。拦截器通过拦截SQL操作,在插入和更新操作时自动填充公共字段,使得开发者不再需要手动设置这些字段。本文详细介绍了实现步骤,并通过示例代码展示了具体实现方法,希望能为您的开发工作提供实用的指导和帮助。
625 13
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
1846 5
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
前端开发 开发者
如何理解 package.json 中的 proxy 字段?
`package.json` 中的 `proxy` 字段用于配置代理服务器,帮助前端开发中解决跨域问题及模拟后端响应。其基本概念、使用场景及配置方法将在本文中详细探讨,助力开发者高效调试与测试。
385 4
|
JSON Java 数据格式
springboot中表字段映射中设置JSON格式字段映射
springboot中表字段映射中设置JSON格式字段映射
499 1
|
SQL Java 数据库连接
mybatis如何仅仅查询某个表的几个字段
【10月更文挑战第19天】mybatis如何仅仅查询某个表的几个字段
561 1
|
JSON API 数据格式
postman如何发送json请求其中file字段是一个图片
postman如何发送json请求其中file字段是一个图片
501 4
|
缓存 Java 数据库连接
我们后端程序员不是操作MyBatis的CRUD Boy
大家好,我是南哥。一个对Java程序员进阶成长颇有研究的人,今天我们接着新的一篇Java进阶指南。为啥都戏称后端是CRUD Boy?难道就因为天天怼着数据库CRUD吗?要我说,是这个岗位的位置要的就是你CRUD,你不得不CRUD。哪有公司天天能给你搭建高并发、高可用、大数据框架的活呢,一条业务线总要成长吧,慢慢成熟了就要装修工来缝缝补补、美化美化,也就是CRUD的活。不能妄自菲薄CRUD Boy,我们是后端工程师。今天来指南下操作数据库之MyBatis框架。
315 3
我们后端程序员不是操作MyBatis的CRUD Boy
|
Java 数据库连接 数据库
mybatis plus 更新值为null的字段
mybatis plus 更新值为null的字段
250 7
下一篇
oss云网关配置