MySql数据库对于二进制转为流然后反序列化怎么 *** 作

MySql数据库对于二进制转为流然后反序列化怎么 *** 作,第1张

以下即为范例代码 --- 按照说明编译即可用,稍加修改即可存储2进制文件

view plaincopy to clipboardprint?

/*

mysql数据库存储二进制数据 linux

用途: 用 mysql_stmt_send_long_data()来向blob字段写入2进制数据流.

注意点:需要注意的是bind结构的buffer_type字段,必须与要输入的数据类型相符,

如:只写入一个long 数据,则用MYSQL_TYPE_LONG,写入字符流,用MYSQL_TYPE_STRING,

写入2进制数据流,用MYSQL_TYPE_BLOB

具体这个参数各字段的含义参见 mysql5.0手册

Compile: g++ -I/usr/include/mysql -L/usr/lib/mysql -lmysqlclient mysql_test.cpp

准备工作:

create database test

use test

CREATE TABLE `bintest` (

`id` int(11) NOT NULL default 0,

`data` blob

) ENGINE=MyISAM

*/

取二进制数据:

一样的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语句用法不变。

把你要保存的数据转换为BYTE[]然后保存

下面是读取文件然后保存

stream = new FileStream(control.Text, FileMode.Open, FileAccess.Read, FileShare.ReadWrite)

bReader = new BinaryReader(stream)

MySQLParameter par = new MySQLParameter("?FieldName", System.Data.DbType.Binary)

par.Value = bReader.ReadBytes((int)stream.Length)

command.Parameters.Add(par)


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存