Mybatis-plus操作json字段实战

Mybatis-plus操作json字段实战后端动态列设计与实现三部曲,这是最后一步,使用java语言,结合mybatis-plus神技操作json字段。简单介绍下mybatis-plus,大厂中mybatis使用的非常多,而mybatis-plus是基于mybatis做了扩展,进一步增强,在不影响数据存储的情况下,简化操作方式。有兴趣的朋友可以去官网了解:https://www.baomidou.com/1、架构图2、功能3、表结构DROPTABLEIFEXISTSuser;CREATETABLEuser(……

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

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

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

1、架构图

Mybatis-plus操作json字段实战

2、功能

Mybatis-plus操作json字段实战

3、表结构

DROP TABLE IF EXISTS user;CREATE TABLE user(  id BIGINT(20) NOT NULL 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));
INSERT INTO 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": "青岛"}');

Jetbrains全家桶1年46,售后保障稳定

4、实体定义 

package com.baomidou.mybatisplus.samples.typehandler.entity;

import com.baomidou.mybatisplus.annotation.TableField;import com.baomidou.mybatisplus.annotation.TableName;import com.baomidou.mybatisplus.extension.handlers.FastjsonTypeHandler;import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import lombok.Data;import lombok.experimental.Accessors;
/**用户实体对应表 user * @author hubin * @since 2018-08-11 */@Data@Accessors(chain = true)@TableName(autoResultMap = true)public class User {
  
      private Long id;    private String name;    private Integer age;    private String email;
    /**     * 注意!!必须开启映射注解     *     * @TableName(autoResultMap = true)     *     * 以下两种类型处理器,二选一 也可以同时存在     *     * 注意!!选择对应的 JSON 处理器也必须存在对应依赖包     */    @TableField(typeHandler = JacksonTypeHandler.class)    private Wallet wallet;
    @TableField(typeHandler = FastjsonTypeHandler.class)    private OtherInfo otherInfo;}
package com.baomidou.mybatisplus.samples.typehandler.entity;
import java.util.List;
import lombok.Data;
/** * 钱包 */@Datapublic class Wallet {
  
      /**     * 名称     */    private String name;    /**     * 各种货币     */    private List<Currency> currencyList;}

package com.baomidou.mybatisplus.samples.typehandler.entity;
import lombok.Data;
/** * 货币 */@Datapublic class Currency {
  
      /**     * 类型: 人民币 RMB , 美元 USD     */    private String type;    /**     * 金额     */    private Double amount;}
package com.baomidou.mybatisplus.samples.typehandler.entity;
import lombok.Data;
/** * 其他信息 */@Datapublic class OtherInfo {
  
      /**     * 性别     */    private String sex;    /**     * 居住城市     */    private String city;}

5、Dao定义 ​​​​​​​

package com.baomidou.mybatisplus.samples.typehandler.mapper;

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

6、类型转换器​​​​​​​

package com.baomidou.mybatisplus.samples.typehandler.config;
import com.baomidou.mybatisplus.extension.handlers.GsonTypeHandler;import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;import com.fasterxml.jackson.databind.ObjectMapper;import com.google.gson.Gson;import org.springframework.boot.CommandLineRunner;import org.springframework.stereotype.Component;
/** * @author miemie * @since 2019-11-28 */@Componentpublic class MpJsonConfig implements CommandLineRunner {
  
  
    /**     * 可以set进去自己的     */    @Override    public void run(String... args) throws Exception {
  
          JacksonTypeHandler.setObjectMapper(new ObjectMapper());        GsonTypeHandler.setGson(new Gson());    }}

 7、测试

​​​​​​​

package com.baomidou.mybatisplus.samples.typehandler;
import javax.annotation.Resource;
import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;
import com.baomidou.mybatisplus.samples.typehandler.entity.User;import com.baomidou.mybatisplus.samples.typehandler.mapper.UserMapper;
/** * <p> * 内置 类型处理器 演示 * </p> * * @author hubin * @since 2018-08-11 */@RunWith(SpringRunner.class)@SpringBootTestpublic class SampleTest {
  
  
    @Resource    private UserMapper userMapper;
    /**     * 自定义类型处理器演示参考 mybatis-plus-sample-deluxe 模块     */    @Test    public void test() {
  
          User Jone = userMapper.selectById(1);        System.out.println(Jone);        System.err.println(Jone.getName());
        User Jack = userMapper.selectById(1);        System.err.println(Jack.getName());    }}

结果如下:​​​​​​​

2020-11-22 12:46:58.164  INFO 3168 --- [           main] c.b.m.samples.typehandler.SampleTest     : Started SampleTest in 4.125 seconds (JVM running for 5.707)2020-11-22 12:46:58.477 DEBUG 3168 --- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>  Preparing: SELECT id,name,age,email,wallet,other_info FROM user WHERE id=?2020-11-22 12:46:58.509 DEBUG 3168 --- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==> Parameters: 1(Integer)2020-11-22 12:46:58.713 DEBUG 3168 --- [           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-22 12:46:58.715 DEBUG 3168 --- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==>  Preparing: SELECT id,name,age,email,wallet,other_info FROM user WHERE id=?2020-11-22 12:46:58.715 DEBUG 3168 --- [           main] c.b.m.s.t.mapper.UserMapper.selectById   : ==> Parameters: 2(Integer)2020-11-22 12:46:58.716 DEBUG 3168 --- [           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-22 12:46:58.736  INFO 3168 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown initiated...2020-11-22 12:46:58.747  INFO 3168 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown completed.

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

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

2、注册工具类,MpJsonConfig.

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/226879.html原文链接:https://javaforall.net

(0)
上一篇 2025年6月22日 下午7:22
下一篇 2025年6月22日 下午8:01


相关推荐

  • C# SplitContainer 控件详细用法

    C# SplitContainer 控件详细用法1.可以将Windows窗体SplitContainer控件看作是一个复合体,它是由一个可移动的拆分条分隔的两个面板。当鼠标指针悬停在该拆分条上时,指针将相应地改变形状以显示该拆分条是可移动的。使用SplitContainer控件,可以创建复合的用户界面(通常,在一个面板中的选择决定了在另一个面板中显示哪些对象)。这种排列对于显示和浏览信息非常有用。拥有两个面板使您可以聚合不同区域中的信息,并且用户可以轻松地使用拆分条(也称为“拆分器”)调整面板的大小。另外,还可以嵌套多个SplitC…

    2022年7月18日
    75
  • ISO IEC 27001 企业信息安全管理要求[通俗易懂]

    ISO IEC 27001 企业信息安全管理要求[通俗易懂]ISO27001和ISO20000认证已经成为企业核心竞争力的重要标志。ISOIEC270012013中文版-制造文档类资源-CSDN下载ISOIEC270012013中文版更多下载资源、学习资料请访问CSDN下载频道.https://download.csdn.net/download/std86021/83901501?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522164816627616780255250066%2522%252C%

    2025年6月6日
    3
  • java图书馆新地址_自学Java后,收藏的9个免费学习资源!

    java图书馆新地址_自学Java后,收藏的9个免费学习资源!程序员书库(ID:OpenSourceTop)编译l链接:https://www.aitrends.com/features/top-ai-books-for-summer-reading-in-2019/无论你想学什么,在互联网上都可以找到许多有用的资源,甚至很多都是免费的,你只需要投入时间和精力,不过话说回来,你很难在这些参吃不齐的课程里选择出自己想要的,一不留神还有可能走弯路今天,…

    2022年7月8日
    30
  • 【转载】5种网络IO模型

    【转载】5种网络IO模型

    2021年11月18日
    51
  • 敏捷测试的特点_敏捷测试流程特点是

    敏捷测试的特点_敏捷测试流程特点是敏捷测试的特点敏捷测试就是符合敏捷宣言思想,遵守敏捷开发原则,在敏捷开发环境下能够很好地和其整体开发流程融合的一系列的测试实践,这些实践具有鲜明的敏捷开发的特征,如TDD、ATDD、结对编程、持续测试等。和传统测试的区分,可以概括如下:1)传统测试更强调测试的独立性,将“开发人员”和“测试人员”角色分得比较清楚。而敏捷测试可以有专职的测试人员,也可以是全民测试,即在敏捷测试中,可以没有“测试人员”

    2025年6月28日
    4
  • Linux系统搭建FTP服务器教程

    Linux系统搭建FTP服务器教程Liunx 系统下有好几款很不错的 ftp 服务 各有特点 适应于不同的应用场合 一般在各种 Linux 的发行版中 默认带有的 ftp 软件是 vsftp 本文是针对 CentOs7 系统下搭建 vsftpd 服务为例 1 首先确定系统中已经安装了 vsftpd 软件 查看命令 rpm qvsftpdrpm qa grepvsftpd2 安装 vsftpd 以 yum 安装为例 yuminstall yvsftpd3 关闭 selinux 和 iptables 也可配置防火墙相关访问策略

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号