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;
}
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL中文数字同时出现导致乱码问题一般是由于字符集设置不正确所导致的。在编写MySQL查询时,我们需要确保数据库连接使用的是正确的字符集。 首先,我们需要确认MySQL数据库的字符集设置。可以通过执行以下查询语句来查看数据库当前的字符集设置: ```sql SHOW VARIABLES LIKE 'character_set%'; ``` 确保以下两个参数的值是utf8或utf8mb4: - character_set_client - character_set_connection 如果字符集设置不正确,我们可以通过以下方式来修复这个问题。 1. 修改MySQL配置文件:可以编辑MySQL配置文件my.cnf或my.ini,并在[mysqld]部分添加以下两行配置: ```bash [mysqld] character_set_server = utf8mb4 collation_server = utf8mb4_unicode_ci ``` 2. 修改数据库的默认字符集:可以通过执行以下命令来修改数据库的默认字符集: ```sql ALTER DATABASE database_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ``` 需要将database_name替换为实际的数据库名。 3. 修改表的字符集:可以通过执行以下命令来修改表的字符集: ```sql ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ``` 需要将table_name替换为实际的表名。 4. 修改连接时的字符集:可以在连接MySQL数据库时指定字符集,例如在连接Java应用程序时可以使用以下代码: ```java String url = "jdbc:mysql://localhost:3306/database_name?useUnicode=true&characterEncoding=utf8mb4"; Connection conn = DriverManager.getConnection(url, username, password); ``` 需要将database_name替换为实际的数据库名。 通过以上步骤,我们可以解决MySQL中文数字同时出现导致的乱码问题。确保数据库连接使用的字符集与文本数据的字符集一致,即可正确显示中文数字。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值