clob用于存储大量的文本数据。大字段的 *** 作常常以流的方式处理。
2.blob
blob用于存储二进制数据,常常为图片或音频。
MySQL中,BLOB是个类型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大大小上不同。MySQL的四种BLOB类型
TinyBlob: 最大 255字节
Blob: 最大 65K
MediumBlob:最大 16M
LongBlob: 最大 4G
注意:如果你存储的文件过大,数据库的性能会下降很多。
2、PHP *** 作BLOB案例
<?php
mysql_connect( "localhost", "root", "password")//连接数据库
mysql_select_db( "database")//选定数据库
//数据插入:
$CONTENT="测试内容" //$CONTENT为新闻内容
$COMPRESS_CONTENT = bin2hex(gzcompress($CONTENT))
$result=mysql_query( "insert into news (content) value ('$COMPRESS_CONTENT')")//数据插入到数据库news表中
//展示:
$query = "select data from testtable where filename=$filename"
$result = mysql_query($query)
$COMPRESS_CONTENT=@gzuncompress($result["COMPRESS_CONTENT"])
echo $COMPRESS_CONTENT
?>
[2]存储图片
<?php
mysql_connect( "localhost", "root", "password")//连接数据库
mysql_select_db( "database")//选定数据库
//存储:
$filename="" //这里填入图片路径
$COMPRESS_CONTENT = addslashes(fread(fopen($filename, "r"), filesize($filename)))//打开文件并规范化数据存入变量$data中
$result=mysql_query( "insert into news (content) value ('$COMPRESS_CONTENT')")//数据插入到数据库test表中
//展示:
ob_end_clean()
Header( "Content-type: image/gif")
$query = "select data from testtable where filename=$filename"
$result = mysql_query($query)
echo $result["COMPRESS_CONTENT"]
?>
取二进制数据:一样的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语句用法不变。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)