vc++ mysql解决思路
vc++ mysql
各位高手 小鸟有个问题像大鸟请教
环境:
服务器 centos 7 +mysql
IDE:vs2015
配置:
vc++连接mysql,用的api连接的
mysql字符集是utf8_bin
连接时配置 mysql_set_character_set(&myconn, "utf8")
项目设置的unicode字符集
cpp保存为unicode 1200的
读取中文字符的时候 是乱码... 错在哪里?
mysql_set_character_set(&myconn, "gbk") 或是gb2312 中文显示没问题
数据是用phpmyadmin插入的...
------解决思路----------------------
vc中utf8要转换为unicode。
------解决思路----------------------
MySQL中的中文需要转换,提供我程序中的2个转换函数可试试。GB2312和GBK都属于ANSI
各位高手 小鸟有个问题像大鸟请教
环境:
服务器 centos 7 +mysql
IDE:vs2015
配置:
vc++连接mysql,用的api连接的
mysql字符集是utf8_bin
连接时配置 mysql_set_character_set(&myconn, "utf8")
项目设置的unicode字符集
cpp保存为unicode 1200的
读取中文字符的时候 是乱码... 错在哪里?
mysql_set_character_set(&myconn, "gbk") 或是gb2312 中文显示没问题
数据是用phpmyadmin插入的...
------解决思路----------------------
vc中utf8要转换为unicode。
------解决思路----------------------
MySQL中的中文需要转换,提供我程序中的2个转换函数可试试。GB2312和GBK都属于ANSI
// ANSI To UNCODE转换
CString CStringProc::AnsiToUnicode(char * szAnsi, int len)
{
CString str;
// ansi to unicode
//预转换,得到所需空间的大小
int wcsLen;
if(len>0)
wcsLen=len;
else
wcsLen= ::MultiByteToWideChar(CP_ACP, NULL, szAnsi, strlen(szAnsi), NULL, 0);
//分配空间要给'\0'留个空间,MultiByteToWideChar不会给'\0'空间
wchar_t* wszString = new wchar_t[wcsLen + 1];
//转换
::MultiByteToWideChar(CP_ACP, NULL, szAnsi, strlen(szAnsi), wszString, wcsLen);
//最后加上'\0'
wszString[wcsLen] = '\0'; // UNICODE字串
str=wszString;
delete[] wszString;
return str;
}
// Unicod To ANSI转换
int CStringProc::UnicodToAnsi(CString str,char* buff)
{
int len=0;
// UNICODE编码 转换成 ANSI编码
len = ::WideCharToMultiByte(CP_ACP, NULL, str,
str.GetLength(), NULL, 0, NULL, NULL); // 取字串长度
::WideCharToMultiByte(CP_ACP, NULL, str, str.GetLength(),
buff, len, NULL, NULL);
buff[len++]=0x00; // 写字串尾部结束标志
return len; // 转换长度
}