b2科目四模拟试题多少题驾考考爆了怎么补救
b2科目四模拟试题多少题 驾考考爆了怎么补救

c/vc/c++ 将文件保存到mysql(longblob类型)(2)

电脑杂谈  发布时间:2019-11-09 22:04:10  来源:网络整理

if ( !(mysql_res = mysql_store_result(mysql)) )g_error("Failed Store Result : Error : %s\n", mysql_error(mysql));

mysql_field = mysql_fetch_field(mysql_res);g_print("Field name : %s\n", mysql_field->name);

mysql_row = mysql_fetch_row(mysql_res);FILE *fichier;fichier = fopen("photo_2.png", "wb");fwrite(mysql_row[0], strlen(mysql_row[0]), 1, fichier);fclose(fichier);mysql_close(mysql);g_free(mysql);return 0;}

other example again.

c++ mysql保存图片_c# 调用mysql存储过程实例_c mysql保存图片

c++ mysql二进制存取,blob存取

2010年05月17日 星期一 3:31 P.M.

取二进制数据:

一样的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子句都是stringc++ mysql保存图片,以'\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 "<<m_strTableName<<"(roleid,playerdata,dynamicdata) VALUES("<<dwDBRoleID

<<",'"<<m_pDBAccess->ConvertBinaryToString(pData,nLen)<<"','')";

assert(m_pDBAccess);

m_pDBAccess->ExecuteSQL(strSQL.str());

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

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

方法二:

上面的方式,你会看到,你每天都应该转换数据,传指针c++ mysql保存图片,传大小等一系列复杂操作,是不是顺序很混乱,过程很枯燥。mysql也为你提供了此外一种方法,那就是MYSQL_BIND。将数据操作统一化,统一麻烦化。mysqlbind是一个结构体,根据个人不同需求填充各个数据成员可以存储任意种类数据,当然包含blob。

bool CMySqlAccess::SetBinaryField(std::string& strCondition,void* pDataIn,int nDataLen)

{

if( ! mysql_stmt_prepare( m_pMySqlStmt, strCondition.c_str(), strCondition.length() ) )

c mysql保存图片_c# 调用mysql存储过程实例_c++ mysql保存图片

{

memset(&m_MySqlBind,0,sizeof(MYSQL_BIND));

m_MySqlBind.buffer_type = MYSQL_TYPE_BLOB;

(*m_MySqlBind.length) = nDataLen;

memcpy(m_MySqlBind.buffer,pDataIn,nDataLen);

if(!mysql_stmt_bind_param(m_pMySqlStmt, (MYSQL_BIND *)&m_MySqlBind))

{

if(!mysql_stmt_execute(m_pMySqlStmt))

{

return true;

}

}

}

int nRes=GetDBErrorCode();

CLogOutStream errLog(crazy::ERROR_LEVEL,THIS_CLASS_NAME);

errLog<<"MySql Query Failed:\""<<strCondition<<"\" ,ErrorCode:"<<nRes<<crazy::logEnd;

return false;

}

这个是对某一列blob数据进行存操作。pDataIn和nDataLen分别是一个struct结构体和构架体大小。填充完毕mysqlbind之后即可对二进制列进行传输了。可能你会问,没有指定哪一列呢,对。哪一列是在strCondition语句后面的,这是一个预处理语句。在预处理语句后面,有一个符号: ? 。问号,问号的位置代表了mysqlbind数据对应的位置。

INSERT INTO test_table(date_field, time_field, timestamp_field) VALUES(?,?,?)

上面这个词语,有3个问号,三个问号分别对应test_table的三列.每个问号呢又对应一个mysqlbind数据结构。那么我们在mysql_stmt_bind_param函数调用时,就需要传入一个mysql_bind 数组。MYSQL_BIND m_MySqlBind[3].

填充整个函数数据,即对应三个问号内容。

用例:

MYSQL_BINDbind[3];

MYSQL_STMT *stmt;

strmov(query, "INSERT INTO test_table(date_field, time_field, timestamp_field) VALUES(?,?,?");

//初始化stmt

stmt = mysql_stmt_init(mysql);

//预处理语句

mysql_stmt_prepare(mysql, query, strlen(query));

//初始化参数

bind[0].buffer_type= MYSQL_TYPE_DATE;

bind[0].buffer= (char *)&ts;

bind[0].is_null= 0;

bind[0].length= 0;

bind[1]= bind[2]= bind[0];

//绑定参数123

mysql_stmt_bind_param(stmt, bind);

//执行预处理mysql语句

mysql_stmt_execute(stmt);

还没看懂就个人去看mysql文档了,其实上面讲得很明白,只要找对几个函数,就可以把search出来了


本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/tongxinshuyu/article-129451-2.html

相关阅读
    发表评论  请自觉遵守互联网相关的政策法规,严禁发布、暴力、反动的言论

    • 李树斌
      李树斌

      中国军民有权抗击美舰美军

    热点图片
    拼命载入中...