日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySql中json类型的使用___mybatis存取mysql中的json

發布時間:2025/3/12 数据库 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySql中json类型的使用___mybatis存取mysql中的json 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MySql中json類型的使用

MySQL從5.7.8起開始支持JSON字段,這極大的豐富了MySQL的數據類型。也方便了廣大開發人員。但MySQL并沒有提供對JSON對象中的字段進行索引的功能,至少沒有直接對其字段進行索引的方法。本文將介紹利用MySQL 5.7中的虛擬字段的功能來對JSON對象中的字段進行索引。


一、使用json的目的

1、可以直接過濾記錄
2、可以直接update,而無須先讀取
3、可以在一條SQL中完成多條紀錄的修改!
4、通過json類型,完美的實現了表結構的動態變化
5、通過計算生成列且在該列上建立索引。提高查詢效率

二、開始使用

1.建表

建表語句如下:

CREATE TABLE `msg_info` (`id` int(10) unsigned NOT NULL,`message` json NOT NULL,PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2.插入數據

insert into msg_info values (1,'{"name":"zhangsan","phone":"13752763211"}'); insert into msg_info values (2,'{"name":"lisi","phone":"13752763222"}');

3.查詢更新操作

1、過濾記錄

select * from msg_info where message->'$.phone'='13752763211';

2、查詢json內指定字段

select message->'$.name' from msg_info; # 這樣查詢出來的字段是帶雙引號的,使用如下語句可去除雙引號,也可以使用關鍵字JSON_UNQUOTE select message->>'$.name' from msg_info;

3、直接更新json串內的字段內容

UPDATE msg_info set message = JSON_SET(message, '$.name', 'lili') WHERE id = 1; # 為json串添加字段 update msg_info set message = JSON_INSERT(message, '$.age', 30) WHERE id = 1;

3.動態擴展字段

1、為json添加虛擬字段

ALTER TABLE msg_info ADD v_phone varchar (12) GENERATED ALWAYS AS (JSON_UNQUOTE(message->'$.phone' ));

2、為虛擬字段創建索引,提高查詢效率

# 通過執行計劃可以查看創建索引前后的變化 ALTER TABLE msg_info ADD INDEX idx_phone(v_phone);

mybatis存取mysql中的json

mysql 5.7后新增了一個json類型字段,以往json入庫都是轉字符串,取到前端造成了不少困擾。今天就做了個小例子把這個整合到ssm例子中。

這邊也順便說下如果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}* 出庫:* <resultMap>* <result property="jsonDataField" column="json_data_field" javaType="com.xxx.MyClass" typeHandler="com.adu.spring_test.mybatis.typehandler.JsonTypeHandler"/>* </resultMap>** 用法二:* 1)在mybatis-config.xml中指定handler:* <typeHandlers>* <typeHandler handler="com.adu.spring_test.mybatis.typehandler.JsonTypeHandler" javaType="com.xxx.MyClass"/>* </typeHandlers>* 2)在MyClassMapper.xml里直接select/update/insert。**/ public class JsonTypeHandler<T extends Object> extends BaseTypeHandler<T> {private static final ObjectMapper mapper = new ObjectMapper();private Class<T> clazz;public JsonTypeHandler(Class<T> clazz) {if (clazz == null) throw new IllegalArgumentException("Type argument cannot be null");this.clazz = clazz;}@Overridepublic void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {ps.setString(i, this.toJson(parameter));}@Overridepublic T getNullableResult(ResultSet rs, String columnName) throws SQLException {return this.toObject(rs.getString(columnName), clazz);}@Overridepublic T getNullableResult(ResultSet rs, int columnIndex) throws SQLException {return this.toObject(rs.getString(columnIndex), clazz);}@Overridepublic 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代碼

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.cm.dao.UserDao"><resultMap id="user" type="com.cm.model.UserModel"><id column="id" jdbcType="NUMERIC" property="id"/><result column="name" jdbcType="VARCHAR" property="name"/><result column="age" jdbcType="NUMERIC" property="age"/><result column="hobby" jdbcType="NUMERIC" property="hobby" typeHandler="com.cm.mybaits.JsonTypeHandler"/></resultMap><select id="getAllUsers" resultMap="user">select * from user</select><insert id="addUser"><!--ignore忽略自動增長的主鍵id-->insert ignore into user (name, age, hobby) values (#{id}, #{name} ,#{hobby, typeHandler=com.cm.mybaits.JsonTypeHandler})</insert><update id="updateUser">update user set name=#{name} where id=#{id}</update><delete id="deleteUser" parameterType="String">delete from user where id=#{id}</delete><select id="getUser" resultType="UserModel">select * from user where id = #{id}</select> </mapper>

mysql表結構
 
插入的測試代碼

效果預覽

入庫


取數據

這邊有個坑是mysql 驅動一定要5.1.40,不然取出來的json中文是亂碼。雖然說是低于5.1.36會亂碼,但是我試了5.1.6還是亂碼。

<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.40</version> </dependency>

總結

以上是生活随笔為你收集整理的MySql中json类型的使用___mybatis存取mysql中的json的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。