数据库中存媒体文件的字段用什么类型?一文带你了解二进制大对象BLOB

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 在大数据环境中,BLOB 很常见,并且存储在关系或非关系数据库系统中,描述的是一个二进制形式的大文件,一般可以是视频、音频或图像和图形文件。

你好,这里是网络技术联盟站。

在大数据环境中,BLOB 很常见,并且存储在关系或非关系数据库系统中,本文瑞哥带大家了解一下BLOB,让我们直接开始。

什么是BLOB?

  • 英文全称:Binary Large Object
  • 中文名称:二进制大对象

Jim Starkey是 BLOB 的发明者,它于 1970 年代首次出现,描述的是一个二进制形式的大文件,一般可以是视频、音频或图像和图形文件。BLOB可以具有数 GB 大小的数字存储单元,它被压缩成单个文件,然后存储在数据库中。由于二进制数据只能被计算机读取,并且由数字0和1组成,因此通常需要打开相关程序。

由于 BLOB 文件的原始内容在存储时通常是非结构化的,因此它需要一个数据库名称或类型来处理文件并使其可访问。

典型的 BLOB 文件和类型:

  • 视频(MP4、MOV)
  • 音频 (MP3)
  • 图像(JPG、PNG、PDF、RAW)
  • 图形 (GIF)

BLOB 的类型

共有三种不同类型的 BLOB:

块 BLOB
  • 最常见的 Blob 存储类型
  • 块的集合,每个块都可以通过块 ID 识别
  • 用于流式传输序列数据,如视频
  • 每个块最大为 4 MB
  • 最多可以创建 50000 个块
  • 最大大小 195 GB
  • 多个客户端不可以写入同一个 blob
追加 BLOB
  • 追加 Blob 与块 Blob 类似,但支持追加操作并且专为日志文件而设计
  • 针对追加操作进行了优化
  • 用于记录等活动
  • 每个块最大为 4 MB
  • 最多可以创建 50000 个块
  • 最大大小为 195 GB
  • 多个客户端可以写入同一个 blob
页面 BLOB
  • 专为频繁的读/写操作而设计
  • 为随机读写操作优化的页面集合
  • 用于非顺序读写
  • 一个页面最多可以有 512 个字节
  • 创建的页面数量没有限制
  • 最大大小 1TB
  • 多个客户端不可以写入同一个 blob

BLOB使用场景

媒体

图像、视频和音频数据占用大量空间,有时需要存储但不一定要定期访问。

日志

当软件执行时,它会不断创建一系列事件,这些事件可以记录在日志中以供以后分析,这些数据量会随着时间进行增加,Blob 存储能够以非结构化形式快速、廉价地存储这些数据。但是,对于此场景,blob 存储的成本效益较低,任何日志数据查询都会产生访问费用。

备份和灾难恢复

大多数组织需要保留完整的备份,尤其是从勒索软件攻击中恢复,由于此数据在生产中重复且很少访问,因此 Blob 存储非常适合备份大型数据集。

BLOB在数据库中的使用

二进制大对象由不同的数据库系统以不同的方式存储,数据库的结构通常不适合直接存储 BLOB。

我们来看下每个数据库系统存储大文件对象用的是什么字段:

  • MySQL:BLOB,TINYBLOB(最大 64 KB)、MEDIUMBLOB(最大 16 MB)、LONGBLOB(最大 4 GB)
  • PostgreSQL:BYTEA或通过OID
  • Oracle :BLOB
  • DB2 :BLOB
  • SQL Server:binary, varbinary, text, ntext

总结

BLOB在如今系统中经常遇到此类型,本文用精简的向大家介绍了BLOB的原理、类型和使用场景,希望本文对您有所帮助,

最后感谢您的阅读,如果觉得文章对您有帮助,别忘了点赞👍、收藏⭐哦!有任何问题,欢迎在下方评论区与我讨论!!!

相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
目录
相关文章
|
4月前
|
存储 SQL Java
数据存储使用文件还是数据库,哪个更合适?
数据库和文件系统各有优劣:数据库读写性能较低、结构 rigid,但具备计算能力和数据一致性保障;文件系统灵活易管理、读写高效,但缺乏计算能力且无法保证一致性。针对仅需高效存储与灵活管理的场景,文件系统更优,但其计算短板可通过开源工具 SPL(Structured Process Language)弥补。SPL 提供独立计算语法及高性能文件格式(如集文件、组表),支持复杂计算与多源混合查询,甚至可替代数据仓库。此外,SPL 易集成、支持热切换,大幅提升开发运维效率,是后数据库时代文件存储的理想补充方案。
|
7月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
7月前
|
存储 SQL 数据库
【赵渝强老师】达梦数据库的数据库对象
达梦数据库包含基本与复杂两大类数据库对象。基本对象如表、索引、视图、序列和同义词,通过单一DDL语句创建和管理。表是数据存储核心,支持多种数据类型;索引提升查询速度,常见类型包括聚集、唯一、函数等索引;视图提供虚表功能;序列生成有序整数;同义词简化对象访问。复杂对象包括存储过程、函数和触发器,需用DMSQL语言开发,适用于更复杂的业务逻辑处理。文中通过实例详细介绍了各类对象的创建与使用方法。
320 3
|
8月前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
10月前
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
159 5
|
10月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
10月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
11月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
20天前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
56 3
|
26天前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

热门文章

最新文章