mysql json mybatis_mybatis存取mysql中的json

这篇博客介绍了如何在MySQL 5.7中使用JSON类型字段,并将其与MyBatis集成。作者提供了一个JsonTypeHandler类的实现,用于在入库和出库时处理JSON数据。此外,还提到了IDEA启动Tomcat时可能出现的乱码问题及其解决方法,以及需要注意的MySQL驱动版本问题,以避免中文乱码。
摘要由CSDN通过智能技术生成

mysql 5.7后新增了一个json类型字段,以往json入库都是转字符串,取到前端造成了不少困扰。今天就做了个小例子把这个整合到ssm例子中。

这里插句题外话,因为最近开始改用idea,配置项目的时候出了一大堆问题,这边也顺便说下如果idea在启动tomcat客户端控制台出现乱码处理办法

打开idea安装目录-bin

用记事本打开idea.exe.vmoptions和idea64.exe.vmoptions文件

在文件后面添加一行:-Dfile.encoding=UTF-8

好了进入整体

第一步先配置一个typehandler,代码如下

import java.sql.CallableStatement;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import org.apache.ibatis.type.BaseTypeHandler;

import org.apache.ibatis.type.JdbcType;

import org.codehaus.jackson.map.ObjectMapper;

import org.codehaus.jackson.map.SerializationConfig.Feature;

import org.codehaus.jackson.map.annotate.JsonSerialize.Inclusion;

/**

* mapper里json型字段到类的映射。

* 用法一:

* 入库:#{jsonDataField, typeHandler=com.adu.spring_test.mybatis.typehandler.JsonTypeHandler}

* 出库:

*

*

*

*

* 用法二:

* 1)在mybatis-config.xml中指定handler:

*

*

*

* 2)在MyClassMapper.xml里直接select/update/insert。

*

*

* @author yunjie.du

* @date 2016/5/31 19:33

*/

public class JsonTypeHandler extends BaseTypeHandler {

private static final ObjectMapper mapper = new ObjectMapper();

private Class clazz;

public JsonTypeHandler(Class clazz) {

if (clazz == null) throw new IllegalArgumentException("Type argument cannot be null");

this.clazz = clazz;

}

@Override

public void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {

ps.setString(i, this.toJson(parameter));

}

@Override

public T getNullableResult(ResultSet rs, String columnName) throws SQLException {

return this.toObject(rs.getString(columnName), clazz);

}

@Override

public T getNullableResult(ResultSet rs, int columnIndex) throws SQLException {

return this.toObject(rs.getString(columnIndex), clazz);

}

@Override

public T getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {

return this.toObject(cs.getString(columnIndex), clazz);

}

private String toJson(T object) {

try {

return mapper.writeValueAsString(object);

} catch (Exception e) {

throw new RuntimeException(e);

}

}

private T toObject(String content, Class> clazz) {

if (content != null && !content.isEmpty()) {

try {

return (T) mapper.readValue(content, clazz);

} catch (Exception e) {

throw new RuntimeException(e);

}

} else {

return null;

}

}

static {

mapper.configure(Feature.WRITE_NULL_MAP_VALUES, false);

mapper.setSerializationInclusion(Inclusion.NON_NULL);

}

mapper代码

/p>

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

select * from user

insert ignore into user (name, age, hobby) values (#{id}, #{name} ,#{hobby, typeHandler=com.cm.mybaits.JsonTypeHandler})

update user set name=#{name} where id=#{id}

delete from user where id=#{id}

select * from user where id = #{id}

mysql表结构

c68f7cc9cc96c45110a8e57156a4bed4.png

插入的测试代码

c6754f2d6ef7f065c0535f45ff62118e.png

效果预览

入库

244f3e1f2e6f9517052da44c25a4380d.png

取数据

610100e5e525ddc71cb64144fc8a2098.png

这边有个坑是mysql 驱动一定要5.1.40,不然取出来的json中文是乱码。虽然说是低于5.1.36会乱码,但是我试了5.1.6还是乱码。

mysql

mysql-connector-java

5.1.40

最后附上我的项目是一个SSM框架的小demo,有兴趣的小伙伴可以下载参考

链接:https://pan.baidu.com/s/14yaYRg-fXeyaPN7oWU7-Ow

提取码:dggg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值