嫩芋仔 2018-11-08 06:37 采纳率: 0%
浏览 1467

MYSQ数据库插入BLOB字段

MYSQ数据库怎么插入BLOB字段?用C++怎么实现?请各位大神指教。

  • 写回答

1条回答 默认 最新

  • qq_42046381 2018-11-08 06:54
    关注

    取二进制数据:
    一样的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语句用法不变。

    用例:

    std::ostringstream strSQL;
    strSQL<<"INSERT INTO "<ConvertBinaryToString(pData,nLen)<<"','')";
    assert(m_pDBAccess);
    m_pDBAccess->ExecuteSQL(strSQL.str());

    playerdata是blob二进制类型,pData是指向一个结构体的指针,nLen是结构体的大小。

    上面就可以实现二进制的存储了。

    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题