C/C++ mysql 设置字符集
mysql在C/C++中調(diào)用api設(shè)置連接mysql的編碼方式有以下幾種方法:
1. mysql_set_charset
調(diào)用示例:
[cpp]
ret = mysql_set_character_set(mysql, "utf8");?
說(shuō)明:
推薦使用的設(shè)置方法,與mysql的連接斷開(kāi)自動(dòng)重連后仍能保持設(shè)置的編碼格式,并且影響mysql_real_escape_string函數(shù)功能,使mysql_real_escape_string函數(shù)使用設(shè)置的編碼格式轉(zhuǎn)義字符串。
但該函數(shù)在mysql5.0.5版本以后才支持,故版本太低者...。
2. 執(zhí)行sql語(yǔ)句:SET NAMES UTF8
調(diào)用示例:
[cpp]
ret = mysql_real_query(mysql, "SET NAMES UTF8;",? (unsigned long) strlen ("SET NAMES UTF8;"));?
說(shuō)明:
使用sql語(yǔ)句執(zhí)行,只能影響當(dāng)前與數(shù)據(jù)庫(kù)的連接,斷開(kāi)自動(dòng)重連后編碼格式會(huì)重置為默認(rèn)的配置。
?
3. 設(shè)置MYSQL_SET_CHARSET_NAME屬性
調(diào)用示例:
[cpp]
ret = mysql_options(mysql, MYSQL_SET_CHARSET_NAME, "utf8");?
說(shuō)明:
跟mysql_set_character_set類(lèi)似,斷開(kāi)自動(dòng)重連后仍能保持設(shè)置的編碼格式,只是不會(huì)影響到mysql_real_escape_string函數(shù)。
并且在mysql5.0.5版本都可以使用,低版本可以使用該方法代替。
需要特別說(shuō)明的是只有在調(diào)用mysql_real_connect連接數(shù)據(jù)庫(kù)之前修改該屬性才會(huì)生效。
總結(jié)
以上是生活随笔為你收集整理的C/C++ mysql 设置字符集的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: centos7 redis5.0以前版本
- 下一篇: c/c++操作mysql数据库使用utf