1. 程式人生 > >c++連線mysql的中文編碼問題

c++連線mysql的中文編碼問題

c++連線mysql時,比如查詢語句中含有中文,或者得到結果中含有中文,經常出現編譯出錯或亂碼問題。
VS編譯器預設使用gbk編碼。
如果將mysql設定為utf-8編碼,則需要先將c++中的各種中文字串轉為utf-8編碼輸入mysql,得到的結果為utf-8編碼,需要轉為gbk才能正常顯示。轉來轉去很麻煩。
換個角度,將mysql設定為gbk編碼,這不就大功告成了嗎?附程式碼如下:

#include <iostream>
#include <winsock2.h>
#include "mysql.h"

using namespace std;
int main(int
argc, char* argv[]) { mysql_library_init(NULL, 0, 0); MYSQL mysql; mysql_init(&mysql); if (0 == mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk"))//設定字符集 { cout << "設定字符集成功\n\n" << endl; } if (!mysql_real_connect(&mysql, "localhost", "root"
, "123456", "測試", 3306, NULL, CLIENT_MULTI_STATEMENTS))//連線資料庫 { cout << "not connect mysql" << endl; } else { cout << "welcome to mysql\n\n\n"; } mysql_query(&mysql, "select * from 學生資訊"); //執行SQL語句 MYSQL_RES *result = mysql_use_result(&mysql); //獲取資源
int rowcount = mysql_num_rows(result); //獲取記錄數 unsigned int fieldcount = mysql_num_fields(result); //獲取欄位數 MYSQL_FIELD *field = NULL; //欄位 MYSQL_ROW row = NULL; //記錄 while (row = mysql_fetch_row(result)) { for (unsigned int i = 0; i<fieldcount; i++) { field = mysql_fetch_field_direct(result, i); cout << field->name << ":" << row[i] << "\n"; } } mysql_free_result(result); mysql_close(&mysql); mysql_server_end(); mysql_library_end(); return 0; }