一样的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语句用法不变。
1、连接到mysql数据库服务器,查看默认存储目录位置。
2、关闭mysql服务进程,并创建新的存储位置。
3、在mysql数据文件复制或者移动到新的存储目录,并修改存储目录的目录权限。
4、修改mysql数据库配置文件,修改默认存储目录位置为新的目录位置,修改之前建议先备份配置文件。
5、修改完成后启动mysql服务,并连接数据库查看默认存储目录配置信息,可以看到已经修改为新的存储目录。
out 只是用于事先定义好但没有初始化的变量事例中。如:byte[] data//此时你不知道数据的长度有多少所以不能初始化
public void getdata (out data,int len)
{//在调用这些方法时,你可以明确知道数据有多少了
data = new byte[len]
.......
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)