如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题
作者:Tiantangbujimo7
这篇文章主要介绍了如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
mysql出现Incorrect string value for column ‘表项‘ at row 1错误
今天使用 mysql 编写服务端时遇到中文字符串无法插入数据库表的成员中
报错
如下:
Incorrect string value: '\xB2\xE2\xCA\xD4\xB2\xE2...' for column 'Remark' at row 1
尝试了各种方案,用命令设置格式为 utf8 都不管用
最终解决
直到使用以下指令:
MYSQL_RES* DBModuleMysql::QueryStore( const char * sql,bool noret,my_ulonglong* effect)
{
if( ! m_mysql ) return 0;
if( effect ) *effect = 0;
m_QueryCount ++;
if( 0 != mysql_real_query( m_mysql,sql,(unsigned long)strlen(sql) ) )
{
printf( "On Query: %s, Error: \n", sql );
printf( "%s\n", mysql_error(m_mysql) );
return NULL;
}
if( effect )
{
*effect = mysql_affected_rows( m_mysql );
}
if( noret )
{
return NULL;
}
m_QueryResCount ++;
return mysql_store_result(m_mysql);
}
在代码中使用:
m_pDBModule->QueryStore("set names gbk", true);随后正常插入数据提示成功,使用 SQLyog 查看

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
