当前位置: 首页 > news >正文

保存Json对象到数据库

文章目录

  • 背景
  • 实现方式
    • 1. 直接以 Json 对象保存到数据库
    • 2. 以 String 类型保存到数据库

背景

项目过程中可能需要保存 Json 对象到数据库中。

实现方式

有两种实现方式,一种是直接保存 Json 对象到数据库,这种方式在创建实体类以及编写 Mapper XML 脚本时需要对 Json 对象做格式转换,另一种是直接以字符串保存,取用时使用 JSONObject 解析为 Json 对象。

1. 直接以 Json 对象保存到数据库

  • 创建实体类时,类上加 @TableName 注解,autoResultMap 参数设为 true;
  • 要保存为 Json 格式的字段设置为 JSONObject 类型,添加 @TableField 注解,typeHandler 参数设置为 JacksonTypeHandler.class

如下

import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;@TableName(value = "query_condition", autoResultMap=true)
public class QueryConditionDAO {@TableField(value = "queryCondition", typeHandler = JacksonTypeHandler.class)private JSONObject queryCondition;}

然后在编写 Mapper XML 脚本时,insertupdate 语句中需要对 Json 属性的字段设置 typeHandlerjdbcType,如下

	<update id="updateQueryCondition">update ${tableName}set `query_condition`=#{queryCondition, jdbcType=OTHER, typeHandler=com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler}where `id`=#{id}</update>

2. 以 String 类型保存到数据库

以字符串类型保存很简单,如下

public class QueryConditionDAO {private String queryCondition;}

在查询数据时,通过 JSONObject.parseObject() 方法将字符串解析为 JSONObject 类型即可。

JSONObject queryCondition = JSONObject.parseObject(queryConditionString)

小贴士
通常要保存一个 Json 字符串的话,一般都是比较大的数据,CHARVARCHAR 类型是不够的,而需要用 TEXT 类型来存储。要根据具体的数据量的大小决定使用 TEXT 还是 MEDIUMTEXT 或者是 LONGTEXT

http://www.lryc.cn/news/305444.html

相关文章:

  • 《Docker 简易速速上手小册》第3章 Dockerfile 与镜像构建(2024 最新版)
  • 【Python笔记-设计模式】适配器模式
  • 二分算法(c++版)
  • 【C#】用于基于 UV DLP 的 3D 打印机的切片软件源码解析(一)DLP原理 GUI
  • Javase补充-Arrays类的常用方法汇总
  • 微信小程序-人脸检测-眨眼驱动ESP32蓝牙设备灯
  • 怎么在wifi中实现手机和电脑文件互传
  • 07 STL 简介
  • unity学习(39)——创建(create)角色脚本(panel)——静态(static)
  • MacOS环境下用powerline配置Terminal终端
  • liunx单机项目部署
  • SQL 中如何实现多表关联查询?
  • oracle 设置权限 禁止删除用户
  • 港科夜闻|香港科大计划建立北部都会区卫星校园完善科大创新带,发展未来创新科技 未来医药发展及跨学科教育...
  • linux反弹shell简单使用
  • 前后端分离Vue+nodejs校园论坛bbs系统x450z
  • ChatGPT的能力边界在哪?
  • Sentinel微服务流量治理组件实战下
  • vue+node.js美食分享推荐管理系统 io551
  • 云原生超融合八大核心能力|ZStack Edge云原生超融合产品技术解读
  • 认识K8S
  • K8S-001-Virtual box - Network Config
  • ShardingSphere5.x 分库分表
  • cmake 项目。qt5升级 qt6 报错 error: “Qt requires a C++17 compiler 已解决
  • Flutter Engine 编译
  • 数据可视化在商业领域有哪些重要性?
  • UI风格汇:扁平化风格来龙去脉,特征与未来趋势
  • 【雷达指标】MTI/MTD性能
  • 暴雨服务器:科技创新构建高效、高质、可持续的新质生产力
  • 在 where子句中使用子查询(一)