码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 03【MySQL字符集】



    上一篇:02【数据库的基本操作】


    下一篇:04【DQL查询】

    目录:【MySQL零基础系列教程】


    文章目录

    • 三、MySQL字符集
      • 3.1 DOS命令行下汉字乱码的问题
        • 3.1.1 字符集相关参数:
        • 3.1.2 乱码的原因
        • 3.1.3 客户端编码
        • 3.1.4 数据传递过程


    三、MySQL字符集

    3.1 DOS命令行下汉字乱码的问题

    有的同学可能在MySQL控制台查询时,中文会出现乱码,如下图:

    在这里插入图片描述

    3.1.1 字符集相关参数:

    在MySQL系统中维护了几个关于字符集的变量,我们通过如下命令可以查看到:

    show variables like '%character%';
    
    • 1

    在这里插入图片描述

    和我们有关的有如下参数:

    • character_set_client:客户端采用的字符集

    • character_set_connection:MySQL连接采用的字符集

    • character_set_database:MySQL数据库存储采用的字符集

    • character_set_results:SQL语句结果集采用的字符集

    • character_set_server:MySQL服务器采用的字符集

    • character_set_system:MySQL系统采用的字符集

    3.1.2 乱码的原因

    在windows下,cmd窗口默认采用的是GBK字符集编码的,MySQL将数据的结果全部以UTF8编码(character_set_results),然后数据到了cmd窗口时,cmd窗口以GBK进行解码,因此显示乱码,我们可以更改character_set_results参数:

    -- 只在当前窗口剩下,窗口关闭后失效
    set character_set_results=gbk;
    
    -- 再次查询数据
    select * from student;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    此时数据的结果编码为GBK,windows窗口的编码也为GBK,因此显示正常;

    3.1.3 客户端编码

    我们更改解决了cmd窗口中文显示的乱码,但还有地方有问题;

    我们尝试在cmd窗口执行如下SQL语句:

    insert into student(id,name) values(8,"小军");
    
    • 1

    在这里插入图片描述

    发现插入不进去,Incorrect string value

    因为我们的cmd窗口是采用gbk字符集,我们客户端(character_set_client)采用的是utf8字符集,两个码表不一致,在我们输入中文完毕后,数据被cmd窗口用GBK编码了,但MySQL以为客户端采用的是UTF8编码,因此采用UTF8进行解码,然后进行数据的传递(character_set_connection)

    我们可以修改character_set_client参数:

    set character_set_client=gbk;
    
    -- 插入数据
    insert into student(id,name) values(8,"小军");
    
    -- 再次查询数据
    select * from student;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    3.1.4 数据传递过程

    数据首先被cmd窗口编码(GBK),之后MySQL服务器会根据character_set_client解码,然后根据character_set_connection编码传递到MySQL服务器,MySQL服务器最终按照character_set_server编码进行存储;

    在这里插入图片描述

    一般来说character_set_client、character_set_connection、character_set_results都应该保持一致,我们可以通过如下命令来统一设置这三个参数的值:

    set names gbk;
    
    • 1

    在这里插入图片描述

  • 相关阅读:
    永久删除怎么恢复?小白适用
    ATA-2168高压放大器用途有哪些方面
    java-jni 十进制转十六进制应用,根据基址获取包裹首地址
    jetson xiaver NX 安装tensorflow object detection api 遇到的tensorflow-addons 不能安装问题
    MySQL基础-事务
    java基础巩固-宇宙第一AiYWM:为了维持生计,Spring全家桶_Part1-3(学学Spring源码呗:默认的标签和自定义标签是咋解析的)~整起
    leetcode-67:二进制求和
    推荐一些小而美的互联网公司
    为什么说企业需要MES系统? MES系统的作用和意义是什么?
    哈工大李治军老师操作系统笔记【9】:内核级线程(Learning OS Concepts By Coding Them !)
  • 原文地址:https://blog.csdn.net/Bb15070047748/article/details/126563649
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号