mybatis mybatisplus 写入,读取json & mysql json常用函数

实体类 autoResultMap  = true 在plus查询中 自动读取json

typeHandler = JacksonTypeHandler.class 写入时转为json字符串写入


@TableName(value = "xxx",autoResultMap = true)
public class xxx 
{


    @TableField(typeHandler = JacksonTypeHandler.class)
    private List<String> xxx;

...

mybatis 中读取json

typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler"/> 声明字段为json 指定转换器 

resultMap="xxxid"> 设置查询函数的输出类型


    <resultMap id="xxxid" type="xxxType">

        <result column="xxx" jdbcType="OTHER" property="xxx" javaType="java.util.List"
                typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler"/>

    </resultMap>

    <select id="xxxselect" resultMap="xxxid">

...

--  查询 id json字段wordvalues中的学员姓名 命名为name 使用双引号处理json中的特殊字符 并且使用JSON_UNQUOTE 去除结果的引号
SELECT
	id,
	JSON_UNQUOTE( JSON_EXTRACT( wordvalues, '$."${学员姓名}"' ) ) AS 'name',
	JSON_UNQUOTE( JSON_EXTRACT( wordvalues, '$."${学员费用}"' ) ) AS 'price',
	JSON_UNQUOTE( JSON_EXTRACT( res, '$.data.url' ) ) AS url,
	maketime 
FROM
	`ry-cloud`.`app_markword` -- 	查询必须有签名的 这里可以优化下
	
WHERE
	`wordmore` LIKE '%g", "zhangKey": "${学%' -- 	 根据 wordvalues 合同编号 唯一分组
	
GROUP BY
	JSON_EXTRACT( wordvalues, '$."${合同编号}"' ) 
ORDER BY
	id DESC 
	LIMIT 0,
	1000

JSON_UNQUOTE(a) 如果a是json去除a的引号输出

JSON_EXTRACT(a,'$."b"') 对json字段a 取其字段b " 为处理 b中含有特殊字符的

需求

在array中查询 item中某个值的选项

aaa 字段

bbb 当中的值

where JSON_CONTAINS( aaa, '"bbb"' )

在array中查询 obj中某个值的选项

某个字段的值 统一为以下格式 如何查询 userid为 xxx的呢

[
    {
        "tags":[

        ],
        "remark":"5.14梁盼-田毅-初级中药无忧",
        "userid":"aaa",
        "add_way":2,
        "createtime":1620974058,
        "description":"",
        "oper_userid":"aaa",
        "remark_mobiles":[
            "xxx"
        ]
    }
]

用 两个函数

JSON_CONTAINS 这个是查询 数组的 

follow_user 为哪个字段的数组

JSON_OBJECT 为数组的值是哪个

...
WHERE
	JSON_CONTAINS(
	follow_user,
	JSON_OBJECT( 'userid', 'aaa' ))
...

Mybatis-plus支持读取json类型数据,方法如下: 1. 首先,在数据库中创建一个json类型的字段,如下所示: CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, `address` varchar(255) DEFAULT NULL, `info` json DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 2. 在Java实体类中,为info字段添加注解@JSONField,如下所示: public class User { private Long id; private String name; private String address; @JSONField(serializeUsing = JSONObjectSerializer.class, deserializeUsing = JSONObjectDeserializer.class) private JSONObject info; // 省略getter和setter方法 } 3. 在Mybatis-plus的mapper接口中,使用@Results和@Result注解映射json字段,如下所示: @Results(id = "userResultMap", value = { @Result(property = "id", column = "id", id = true), @Result(property = "name", column = "name"), @Result(property = "address", column = "address"), @Result(property = "info", column = "info", javaType = JSONObject.class, typeHandler = JSONTypeHandler.class), }) public interface UserMapper extends BaseMapper<User> {} 4. 在配置文件中,配置typeHandlersPackage为org.apache.ibatis.type,如下所示: mybatis-plus: configuration: map-underscore-to-camel-case: true log-impl: org.apache.ibatis.logging.stdout.StdOutImpl type-handlers-package: org.apache.ibatis.type 5. 最后,就可以在mapper接口中使用Mybatis-plus提供的方法读取json类型数据了,如下所示: User user = userMapper.selectOne(Wrappers.<User>lambdaQuery().eq(User::getId, 1L)); JSONObject info = user.getInfo(); 以上就是Mybatis-plus读取json类型数据的方法实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值