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

15 mysql tiny/meidum/long blob/text 的数据存储

前言

这里主要是 由于之前的一个 datetime 存储的时间 导致的问题的衍生出来的探究 

探究的主要内容为 int 类类型的存储, 浮点类类型的存储, char 类类型的存储, blob 类类型的存储, enum/json/set/bit 类类型的存储 

本文主要 的相关内容是 tiny/medium/long blob/text 类类型的相关数据的存储  

这部分数据 客户端 和 服务器这边的交互 主要是以字符串的形式交互 

服务器这边的存储 为二进制, 主要是本来就是 二进制 或者 将字符串按照给定的编码进行转换为二进制  

 

text 和 blob 类似, 因此 我们这里 仅仅介绍 blob, text 需要根据当前字段编码转换为 字节序列 

tinyblob, blob, mediumblob, longblob 的差异主要是可以存储的数据量不相同, 单字节存储长度, 双字节存储长度, 三字节存储长度, 四字节存储长度 

 

 

mysql 中 blob的服务器客户端的数据交互

测试的 数据表如下 

CREATE TABLE `tz_test` (`id` int(11) NOT NULL AUTO_INCREMENT,`field1` blob,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8INSERT INTO `test`.`tz_test`(`id`, `field1`) VALUES (1, 'boy,girl');

 

测试脚本如下 

package com.hx.test07;/*** Test06MysqlTimezone** @author Jerry.X.He* @version 1.0* @date 2023/4/24 16:26*/
public class Test06MysqlTimezone {// Test06MysqlTimezonepublic static void main(String[] args) {String url = "jdbc:mysql://10.60.50.16:3306/test?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&autoReconnectForPools=true&useSSL=false";String username = "root";String password = "root";JdbcTemplate jdbcTemplate = Test14GenExpertSql.getMysqlJdbcTemplate(url, username, password);String sql = " select * from tz_test; ";List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);int x = 0;}}

 

mysql 是将给定的 blob 的数据以 字节序列的形式 交互给客户端的

mysql 服务器中对应的类型为 BLOB

80ea2d8d4c4541d786ce63a768d924e2.png

 

 

blob 这边转换, 是从包中获取字节序列

这里是 new byte[] { 0x62, 0x6f, 0x79, 0x2c, 0x67, 0x69, 0x72, 0x6c }

字符串表示为 “boy,girl”

f672087eba0c44e793d98061ad48604b.png

 

与客户端的交互, 获取给定的 blob, 以目标编码成字符串 响应回去

91bfeecf3be34ed0ab156dff47b858d3.png

 

 

mysql 服务器 blob的存储

将给定的 utf8mb4_general_ci 的 “gir1l,unknown” 转换为 binary, 然后 之后以二进制的形式存储

40970f08edfa4276a8627a7b13286578.png

 

记录 带存储的 binary 的长度, 和 数据

88aec98e740f4ebea8977c3c70a3d4ab.png

 

blob 的二进制的转换方式如下, 直接取的 来源字符串 以及 来源编码

然后 转换为 binary, 然后 存储给定的 binary

584ddfa9f3484b14b98e4b8037641a45.png

 

 


 

 

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

相关文章:

  • 【方案】基于视频与AI智能分析技术的城市轨道交通视频监控建设方案
  • mysql8 修改数据存储位置
  • Qt QSlider样式
  • Redis五大数据类型
  • chatGPT训练过程
  • 原神角色数据分析项目说明文档
  • 【Qt】QML-04:自定义变量(属性)property
  • 基于Cadence Allegro无盘设计操作流程
  • 微信小程序 - 2023年最新版手机号快捷登录详细教程
  • Spring_Bean的自动装配
  • 使用boost::geometry::union_ 合并边界(内、外)- 方案一
  • 面向高速公路车辆切入场景的自动驾驶测试用例生成方法
  • Java:SpringBoot整合SSE(Server-Sent Events)实现后端主动向前端推送数据
  • cmd命令行设置 windows 设置环境变量
  • 基于负载均衡的在线OJ实战项目
  • Opencv手工选择图片区域去水印
  • 《向量数据库》——向量数据库跟大模型是什么关系呢?
  • 通过这 5 项 ChatGPT 创新增强您的见解
  • W5500-EVB-PICO主动PING主机IP检测连通性(十)
  • 解释基本的3D理论
  • C# 练习题
  • 解决Linux报错:Swap file “xxxxxx.swp“ already exists
  • 基于飞桨图学习框架的空间异配性感知图神经网络
  • Springboot整合JWT
  • 如何使用Python和正则表达式处理XML表单数据
  • LA@方阵相似@相似矩阵的性质
  • ZLMediaKit 各种推拉流
  • 行业追踪,2023-08-29
  • 【简单】228. 汇总区间
  • Mysql高级语句