mybatis-plus 如何操作json字段

 更新时间:2022年10月27日 09:08:01   作者:阿拉的梦想  
这篇文章主要介绍了mybatis-plus 如何操作json字段,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

1. 演示表格准备

demo表

CREATE TABLE `demo` (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `tag` json DEFAULT NULL,
  PRIMARY KEY (`id`)
)

数据:

idtag
1[3, 4, 5]
2[“abc”]
3[“a”, “b”, “c”]

2. SQL操作JSON

2.1.精确查询

从数组中查询是否包含某个特定元素

注意 ,字符串必须使用单引号+双引号

select * from demo where json_contains(tag,'"a"');
id|tag            |
--+---------------+
 3|["a", "b", "c"]|

2.2.模糊查询

select json_search(‘{“a”:“xyzf”,“b”:{“c”:“sdf”}}',‘all',‘%f%')

select * from doc where json_search(tag,‘all',‘%d%')

其他的不再赘述

3.mybatis-plus中操作JSON字段

3.1自带方法的JSON处理

实体类上要加上自动映射

@TableName(value="doc",autoResultMap = true)

json字段上加上json处理器

@TableName(value="doc",autoResultMap = true)
public class Doc{
    @TableField(value="tag",typeHandler = FastjsonTypeHandler.class)
    private Set<String> tag;
}   

这样,使用mybatis-plus自带的数据库操作方法时,就可以自动映射了。自己写的方法或SQL不管用。

3.2 QueryWrapper查询的JSON处理

数组模糊查询,模糊查询tag字段数组中是否有指定的值。

QueryWrapper<Doc> wrapper = new QueryWrapper<>();
wrapper.isNotNull("json_search(tag,'all',concat('%','" + param.getTag() + "','%'))");

3.3 自定义SQL操作

查询结果需要自定义映射,json字段需要使用typeHandler。

<resultMap id="resourceMap" type="com.demo.common.params.response.Resource" autoMapping="true" >
    <result column="tag" jdbcType="JAVA_OBJECT" property="tag" typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler" javaType="java.util.ArrayList"/>
</resultMap>
<select id="pageOfSearchKey" resultMap="resourceMap"
            parameterType="com.demo.common.params.request.doc.DocPageParam">
    select * from doc where json_search(tag,'all',concat('%',#{param.searchKey},'%'))
</select>

新增JSON中的元素,若已存在则不新增

<update id="addTag" parameterType="com.demo.common.params.request.doc.DocTagParam">
    update doc set tag =json_Array_append(tag,'$',#{param.tag}) , update_time=update_time
    where
    doc_no in
    <foreach collection="param.docNoList" item="docNo" open="(" separator="," close=")">
        #{docNo}
    </foreach>
    and !JSON_CONTAINS(tag,concat('"',#{param.tag},'"'))
</update>

删除JSON中的元素,删除已存在的元素,元素不存在则不删除

    <update id="removeTag">
        UPDATE doc SET tag = JSON_REMOVE(tag, JSON_UNQUOTE(JSON_SEARCH(tag, 'all', #{param.tag}))) WHERE
        JSON_SEARCH(tag, 'all',#{param.tag})
        and doc_no in
        <foreach collection="param.docNoList" item="docNo" open="(" separator="," close=")">
            #{docNo}
        </foreach>
    </update>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Spring容器-BeanFactory和ApplicationContext使用详解

    Spring容器-BeanFactory和ApplicationContext使用详解

    这篇文章主要为大家介绍了Spring容器-BeanFactory和ApplicationContext的使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 使用IDEA开发配置Java Web的初始化过程

    使用IDEA开发配置Java Web的初始化过程

    该教程使用idea开发工具初始化javaweb项目,该运行在tomcat服务器上通过配置项目环境变量保证tomcat正常启动,具体操作配置教程参考下本文
    2021-06-06
  • Java计算几何图形面积的实例代码

    Java计算几何图形面积的实例代码

    这篇文章主要介绍了Java计算几何图形面积的实例代码,需要的朋友可以参考下
    2014-03-03
  • Spring标准的xml文件头实例分析

    Spring标准的xml文件头实例分析

    这篇文章主要介绍了Spring标准的xml文件头实例分析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • SpringBoot中间件之封装统一白名单配置

    SpringBoot中间件之封装统一白名单配置

    这篇文章主要介绍了SpringBoot中间件封装统一白名单配置,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • java之抽象类和继承抽象类解读

    java之抽象类和继承抽象类解读

    这篇文章主要介绍了java之抽象类和继承抽象类,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • RestTemplate返回值中文乱码问题

    RestTemplate返回值中文乱码问题

    这篇文章主要介绍了RestTemplate返回值中文乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • 基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题

    基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题

    这篇文章主要介绍了基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • Spring Boot 中实现跨域的多种方式小结

    Spring Boot 中实现跨域的多种方式小结

    Spring Boot提供了多种方式来实现跨域请求,开发者可以根据具体需求选择适合的方法,在配置时,要确保不仅考虑安全性,还要兼顾应用的灵活性和性能,本文给大家介绍Spring Boot 中实现跨域的多种方式,感兴趣的朋友一起看看吧
    2024-01-01
  • 浅谈Java编程中string的理解与运用

    浅谈Java编程中string的理解与运用

    这篇文章主要介绍了浅谈Java编程中string的理解与运用,还是比较不错的,这里分享给大家,供需要的朋友参考。
    2017-11-11

最新评论