什么是blob,mysql blob大小配置介绍

什么是blob,mysql blob大小配置介绍,第1张

BLOB (binary large object)二进制象存储二进制文件容器计算机BLOB数据库用存储二进制文件字段类型BLOB

文件典型BLOB张图片或声音文件由于尺寸必须使用特殊式处理(例:传、载或者存放数据库)根据Eric Raymond

说处理BLOB主要思想让文件处理器(数据库管理器)理文件关何处理专家强调种处理数据象双

刃剑能引发些问题存储二进制文件使数据库性能降数据库存放体积较媒体象应用程序处理BLOB典型例

mysql BLOB类型

MySQLBLOB类型系列包括:TinyBlob、Blob、MediumBlob、LongBlob几类型间唯区别存储文件同

MySQL四种BLOB类型

类型 (单位:字节)

TinyBlob 255

Blob 65K

MediumBlob 16M

LongBlob 4G

1.MySQL有四种BLOB类型:

·tinyblob:仅255个字符

·blob:最大限制到65K字节

·mediumblob:限制到16M字节

·longblob:可达4GB

2.mybatis对应mysql blob的类型

byte[] imgbytes对应了mysql imgbytes blob类型

3.将base64转成二进制的byte数组。直接就可存储到mysql中

取二进制数据:

一样的sql语句,查询出来即可。只不过二进制数据是个数据块,需要得到数据块的大小和数据指针。

bool CMySqlAccess::GetBinaryField(int nCol,char* &pDataOut,int&nDataLen)

{

if (m_ItemMySqlRow[nCol] != NULL)

{

unsigned long *FieldLength = mysql_fetch_lengths(m_pMySqlResult)

nDataLen = (int)FieldLength[nCol]

pDataOut = (char*)(m_ItemMySqlRow[nCol])

return true

}

else

{

return false

}

}

像通常一样查询后,得到结果集,然后得到第nCol列结果,返回二进制指针结果和二进制长度。返回后必须立马处理或者存储一份。否则mysql将数据销毁,指针所指数据则无效了。

存二进制数据:

mysql语句接受的sql语句都是string,以'\0'结尾的。如果冒然插入二进制数据到sql语句中,要么报错,要么存储错误。此处可以通过mysql提供的函数将数据转换一下即可。

char* CMySqlAccess::ConvertBinaryToString(char* pBinaryData,int nLen)

{

static char s_BinaryData[10240]

mysql_real_escape_string(m_pMySqlConn,s_BinaryData,pBinaryData,nLen)

return s_BinaryData

}

上面这个函数只能单线程使用啊,将一块二进制数据转换为mysql可识别的string数据。这样就直接可以通过mysql的sql语句insert,update来对blob数据进行更新和插入了,sql语句用法不变。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7538894.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-06
下一篇 2023-04-06

发表评论

登录后才能评论

评论列表(0条)

保存