win10 mysql乱码怎么解决_win10 系统解决mysql中文乱码问题

本文介绍了如何解决在Win10系统中遇到的MySQL中文乱码问题。主要步骤包括:查看和修改MySQL字符集,通过在my.ini配置文件中设置`character-set-server=utf8`和`default-character-set=utf8`,然后重启MySQL服务。此外,对于已有数据表,可以使用`ALTER TABLE`命令转换为UTF8编码。
摘要由CSDN通过智能技术生成

问题:

向mysql 数据库插入数据是,出现中文乱码(中文均显示为‘??’)

原因:

mysql 默认的字符集是latin1,所以我么需要改为ut8编码才可以

解决:

1、以管理员权限运行cmd窗口

2、查看当前字符集

>net start mysql

启动mysql服务

>mysql

进入mysql运行环境

>show variables like ‘character%‘;

查看当前字符集编码情况

35ed439f09655b4d693e8bd640363d30.png

其中,character_set_client为客户端编码方式;

character_set_connection为建立连接使用的编码;

character_set_database数据库的编码;

character_set_results结果集的编码;

character_set_server数据库服务器的编码;

只要保证以上四个采用的编码方式一样,就不会出现乱码问题。

3、修改数据库编码格式

>select @@basedir;

在mysql环境中查看mysql的安装位置

73bb3d35aedec283039a44dfa07abc1e.png

找到这个安装位置,下图为安装位置下的文件

221b2c1ae802904f456a9033faf0adf8.png

本机的mysql是通过解压安装的,开始时只有my-default.ini文件,无my.ini文件

这时复制一份my-default.init并重命名为my.ini

打开my.ini文件

在[mysqld] 下添加character-set-server=utf8

在[client] 下添加:default-character-set=utf8

文件如下:

# For advice on how to change settings please see

# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html

# *** DO NOT EDIT THIS FILE. It‘s a template which will be copied to the

# *** default location during install, and will be replaced if you

# *** upgrade to a newer version of MySQL.

[mysqld]

character-set-server=utf8

# Remove leading # and set to the amount of RAM for the most important data

# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.

# innodb_buffer_pool_size = 128M

# Remove leading # to turn on a very important data integrity option: logging

# changes to the binary log between backups.

# log_bin

# These are commonly set, remove the # and set as required.

# basedir = .....

# datadir = .....

# port = .....

# server_id = .....

# Remove leading # to set options mainly useful for reporting servers.

# The server defaults are faster for transactions and fast SELECTs.

# Adjust sizes as needed, experiment to find the optimal values.

# join_buffer_size = 128M

# sort_buffer_size = 2M

# read_rnd_buffer_size = 2M

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

[client]

port=3306

default-character-set=utf8

保存文件

4、重新在mysql环境中查看字符编码

295b7561368138b595abb6c253760061.png

发现这时的字符编码已经改为utf8

5、如果更改字符编码之前已经有创建的数据表,可以通过如下语句,更改已经创建数据表的字符格式

mysql> alter table testapp_article convert to character set utf8;

也可以在创建数据表的时候指定使用utf8编码,方法是在创建语句后加上character set = utf8

如:

create table test_table (

id int auto_increment,

title text,

content text,

posted_on datetime,

primary key (id)

) character set = utf8;

参考:

原文:https://www.cnblogs.com/eye-like/p/11718756.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值