mysql数据库的字符集_mysql数据库中字符集乱码问题原因及解决

前言

有的时候我们在查看数据库数据时,会看到乱码。实际上,无论何种数据库只要出现乱码问题,这大多是由于数据库字符集设定的问题。

下面我们就介绍一下,数据库的字符集的设定及乱码问题的解决。

mysql数据库的字符集

直白的说,字符就像是单个的文字,编码就像是给每个文字的编号,字符集就像是字符与编码的集合,校验规则就是字符集的对应的排序规则,字符集加上对应的校验规则就是语言。(每种字符集可以有多种校对规则,但都有一个默认的校对规则)

mysql数据库可以通过设定字符集,来使用对应的字符集和检验规则来组织字符。就像是解读一片文章的时候用那种语言来解析。例如:中国人常使用的utf8编码,代表的是中文。

mysql可以支持多种字符集。在同一个数据库的不同表,同一个表中的不同字段,都可以指定使用不同的字符集。

mysql的字符集规则

mysql可以设定的字符集:

服务器的字符集

数据库的字符集

表的字符集字

段的字符集

如果在某一个级别没有设置字符集,则它会继承其上一级的字符集。

mysql数据库乱码问题解决方法(即修改字符集方法)

【1】查看mysql支持的字符集

show character set;

aa9136206c5920f2eee1d6990fb053b1.png

【2】查看数据库编码

show variables like 'character_set%';

c93a2958913f177b1671d165c599a4ac.png

【3】查看当前mysql使用的字符集

show variables like 'character%';

f3efbb92664be28f31f55e5b9a671750.png

解析:

character_set_client:客户端请求数据的字符集

character_set_connection:客户机与服务器连接的字符集

character_set_database:默认数据库的字符集;如果没有默认数据库,就会使用 character_set_server指定的字符集(建议不要随意更改)

character_set_filesystem:把 character_set_client转换character_set_filesystem (默认为binary, 不做任何转换)

character_set_results:返回给客户端的字符集

character_set_server:数据库服务器的默认字符集

character_set_system:系统字符集,默认utf8。(用于数据库的表、列和存储在目录表中函数的名字)

character_sets_dir:mysql字符集文件的保存路径

产生乱码的原因

character_set_client与实际不符合

character_set_results与客户端页面不符合

【4】查看当前数据库的校对规则

show variables like 'collation%';

d60f45fe47082fe41e1b57c6ad397493.png

解析:

value的命名规则: 字符集名字+语言+后缀

collation_connection :当前连接的字符集

collation_database :当前日期的默认校对

collation_server :服务器的默认校对

后缀的含义:

ci:不区分大小写

cs:区分大小写

bin:二进制排序

【5】更改字符集

解决乱码问题(一般如下)

<1>临时(只在当前生效,退出后重新进入恢复原来设置)

set character_set_client = 'utf8';

set character_set_connection = 'utf8';

set character_set_results = 'utf8';

set names utf8;

<2>永久(修改完配置文件,需重启mysql)

在mysql的my.cnf的配置文件中修改或添加下列:

[client]

default-character-set = utf8

[mysqld]

character_set_server = utf8

[mysql]

default-character-set = utf8

备注

<1>

关于mysqld下面的参数,使用mysql5.5验证后,下方的写法都可,并非下划线原因导致的修改不成功:

character_set_server = utf8

character-set-server = utf8

<2>

关于配置文件的修改,有时候由于是编译安装,因此mysql的配置文件,不一定是/etc/my.cnf,因此修改后也不会成功。

<3>

修改完配置文件,并重启mysql后。请查看一下,是否字符集和校对规则如下:

如下即为成功,如果是使用Navicat等第3方工具连接,中文仍有乱码,修改一下工具的编码试试

e739e7d9a73a45b3ad9a1f689be78bc3.png

a02761757d9a23611dcaf9eb13b57395.png

到此这篇关于mysql数据库中字符集乱码问题原因及解决的文章就介绍到这了,更多相关mysql数据库字符集乱码问内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/560576.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1主5从mysql数据库_MySQL主从复制虽好,能完美解决数据库单点问题吗?

一、单个数据库服务器的缺点数据库服务器存在单点问题&#xff1b;数据库服务器资源无法满足增长的读写请求&#xff1b;高峰时数据库连接数经常超过上限。二、如何解决单点问题增加额外的数据库服务器&#xff0c;组建数据库集群&#xff1b;同一集群中的数据库服务器需要具有…

惠普z6计算机进不去桌面,HP Z6 桌面工作站 | HP® HK 惠普香港

Intel、Thunderbolt 及 Xeon 均為 Intel Corporation 於美國及/或其他國家或地區的商標。Microsoft 及 Windows 為 Microsoft Corporation 於美國及/或其他國家或地區的註冊商標或商標。NVIDIA 是 NVIDIA Corporation 在美國及其他國家或地區的商標及/或註冊商標。USB Type-C™…

mysql定义条件和处理_mysql sql存储过程条件定义与处理

一、条件定义DECLARE condition_name CONDITION FOR condition_valecondition_value:sqlstate[value] sqldata_value |mysql教程_error_code二、条件处理DECLARE htype HANDLER FOR cond_value[...] sp_statementhandtype_value:sqlstate [value] saltate_value|contentname|sq…

长沙医学院学位计算机考试内容,湖南长沙医学院2017年9月计算机等级考试报名时间...

长沙医学院2017年下半年第49次全国计算机等级考试(以下简称NCRE)将于2017年9月23至25日举行。为做好本次考试报名及相关考务工作&#xff0c;现将有关事项通知如下&#xff1a;一、报名时间&#xff1a;2016年6月7日—2016年6月18日&#xff0c;逾期不接受任何理由的补报名。二…

mysql dnslog_dnslog小技巧

一、dnslog利用场景主要针对无回显的情况。Sql-BlindRCESSRFRFI(Remote File Inclusion)二、原理将dnslog平台中的特有字段payload带入目标发起dns请求&#xff0c;通过dns解析将请求后的关键信息组合成新的三级域名带出&#xff0c;在ns服务器的dns日志中显示出来。三、案例展…

2019哈佛计算机专业录取,2019哈佛大学早申请录取数据公布 录取率再降1个点仅为13.4%...

出结果了&#xff0c;出结果了&#xff0c;作为美国在全球范围内最负盛名的哈佛大学&#xff0c;与近日公布2019美国本科申请提前录取的相关数据。今年哈佛大学本科学院向6,968位在2023届提前录取轮次申请人中的935位发出了录取通知&#xff0c;申请录取率约为13.4%&#xff0c…

mysql中pi是什么意思_MySQL 基础知识与常用命令

MySQLMySQL是一种开放源代码的关系型数据库管理系统(RDBMS)&#xff0c;MySQL数据库系统使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管理。MySQL在过去由于性能高、成本低、可靠性好&#xff0c;已经成为最流行的开源数据库&#xff0c;因此被广泛地应用在Inte…

科幻计算机类小说,短篇科幻小说推荐 | 黄金时代的五部科幻杰作

编注&#xff1a;本文是少数派读书月「我读过的好书」征文活动的入围文章。本文仅代表作者本人观点&#xff0c;少数派对标题和排版略作调整。想了解如何参与本次读书征文&#xff0c;赢取各种丰厚奖品&#xff0c;你可以 点此查看 活动规则和奖品清单。文章包含五个故事的情节…

计算机中丢失msc,mscvr120.dll32位/64位版_修复计算机中丢失msvcr120.dll

mscvr120.dll32位/64位版_修复计算机中丢失msvcr120.dllmscvr120.dll是系统的非常重要的一个文件&#xff0c;相信很多的人都是遇到文件丢失的情况&#xff0c;这个时候就需要你在下载一个dll文件使用了&#xff01;现在就为大家提供最新的dll文件下载&#xff0c;需要的可以看…

mysql解压缩版配置_MySQL 5.6 for Windows 解压缩版配置安装

1、MySQL安装文件分为两种&#xff0c;一种是msi格式的&#xff0c;一种是zip格式的。如果是msi格式的可以直接点击安装&#xff0c;按照它给出的安装提示进行安装(相信大家的英文可以看懂英文提示)&#xff0c;一般MySQL将会安装在C:\Program Files\MySQL\MySQL Server 5.6 该…

计算机二级考试开考多久能出来,【计算机二级】明天就要开考了,你们准备好了吗?...

原标题&#xff1a;【计算机二级】明天就要开考了&#xff0c;你们准备好了吗&#xff1f;计算机二级考试马上要来了现在距离考试只有不到几个小时的时间了不知道各位同学准备的怎么样了呢&#xff1f;人有多大胆&#xff0c;复习拖多晚但这可不是什么好习惯奔赴“战场”之前先…

办公室中有一台计算机连接打印机,办公室就一个打印机,怎么让多个电脑一起用...

中小型企业的办公室一般只配一台打印机&#xff0c;每次打印东西都要把文件拷在U盘再转到连接打印机的那台电脑&#xff0c;很麻烦。那么怎么才能实现打印机多台电脑共享呢&#xff1f;以下把连接打印机的电脑成为“主电脑”&#xff0c;把需要的共享的电脑叫“客电脑”。1.设置…

php修改mysql数据找不到_php 如何修改mysql数据

PHP MYSQL 修改删除数据创建userinfo_update.php&#xff0c;用于查询用户信息&#xff0c;先显示信息&#xff0c;在修改&#xff1a;先通过GET获取用户编号查询用户信息&#xff1a;$sql "select * from user_info where user_id".$_GET[userId]."";$re…

人工智能训练机器人的服务器,人工智能系统教会机器人如何在荒野中行走

对救援人员和户外运动爱好者来说&#xff0c;穿越荒野小径是一项有用的技能&#xff0c;但对机器人来说却很难。这并不是说这些机械动物没有能力在爬上山坡的同时避开倒下的树枝——最先进的机器学习算法可以做到这一点。问题在于它们缺乏通用性&#xff1a;人工智能驱动的机器…

世界手机号码格式_脑炎康复之旅——世界脑炎日病友征文

○○脑炎康复之旅世界脑炎日病友征文2月22日是世界脑炎日(World Encephalitis Day)。2014年发起的世界脑炎日旨在致敬和鼓励全世界经历过脑炎的患者和脑炎医疗工作者。几年来&#xff0c;全球已有1.87亿人次参与世界脑炎日活动。2021年的世界脑炎日即将到来&#xff0c;今年世界…

树莓派和微信和服务器,用树莓派搭建微信公共平台

1、首先你需要一个公网ip&#xff0c; 需要做好映射&#xff0c; 把80端口映射到你的树莓派ip。2、打开你的树莓派终端&#xff0c; 创建文件夹“templates ” 和文件“weixind.py”。3、文件“weixind.py”中写入以下代码。安装“sudo apt-get install python-lxml”。5、申请…

mysql数据异常增长_mysql表到一定数据量后会异常的增长

如题InnoDB的table&#xff0c;里面的字段非常简单&#xff0c;如图中的类型才100多W的数据量&#xff0c;数据是慢慢积累起来的&#xff0c;到了最近发现涨到12G后&#xff0c;会每天成倍的增长&#xff0c;最高到达过50G&#xff0c;而数据量还是那些&#xff0c;longtext的字…

舰r4月28服务器维护,崩坏3 11月28日版本更新维护通知

亲爱的舰长&#xff1a;为了给舰长更好的游戏体验&#xff0c;休伯利安号将在11月28日进行版本更新维护&#xff0c;维护完成后战舰将更新为3.6版本——「绯夜霞隐」。维护时间安卓国服、iOS服和各渠道服&#xff1a;11月28日07:00~12:00全平台服(桌面服)&#xff1a;11月28日0…

vv7无法启动显示发动机故障_点火系统故障引起发动机不能启动的排除方法

点火系统故障引起发动机不能启动的排除方法a 外观检查首先察看点火线圈和b 中央高压线试火拔出分电器上的中央高压线&#xff0c;插入一个放电器(或备用火花塞)并将放电器(火花塞)搭铁&#xff0c;然后接通点火开关&#xff0c;在转动发动机时看放电器(火花塞)(汽車维修网 Http…

织梦重置mysql数据库密码忘记_织梦cms管理员密码忘记了怎么重置找回?

织梦cms是使用比较广泛的一种开源cms程序&#xff0c;使用织梦的朋友基本上都遇到过忘记后台登录密码这个问题&#xff0c;重置登录密码的方法也有很多&#xff0c;今天木子网络教大家的方法是通过mysql数据库来重置修改密码。下面就为大家分享详细的织梦cms管理员密码重置教程…