广告
返回顶部
首页 > 资讯 > 数据库 >MySQL--字符编码和字符集
  • 679
分享到

MySQL--字符编码和字符集

2024-04-02 19:04:59 679人浏览 薄情痞子
摘要

前言: 一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)  保证不出现乱码的思想:保证客户端、服务端

前言:

一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)
  
保证不出现乱码的思想:保证客户端、服务端、数据库、表字符集统一
坑:有的时候,cmd或者linux系统字符集问题,其实数据库是正确的,只是我们执行命令在终端看到的是乱码而已,这时需要设置linux系统字符集
1、查看liunx系统字符集:cat /etc/sysconfig/i18n
2、vim /etc/sysconfig/i18n

  
备注:始终牢记,存放数据的是字段,所以编码最后是以字段的编码为准,数据库和表的编码影响的时候字段的默认值,也就是说在设置了数据库编码之后,新建的表在不指定的情况下就会和数据库编码相同,而不指定字段的编码时,字段的编码和表相同。如果使用 Alter 修改一个表的字符编码,那原来的字段编码并不会发生改变,如果需要修改表编码的同时修改字段的编码,可以使用 convert
 

一、查看是什么字符集

1、查寻数据库是什么字符集
show create database Django\G (djanGo 是数据库名称)

MySQL--字符编码和字符集
 

2、查寻表是什么字符集
show create table auth_group\G (auth_group 是表名称)

MySQL--字符编码和字符集

ENGINE = InnoDB 该表数据库引擎是InnoDB
DEFULT CHARSET=utf8 该表字符集是utf8
COLLATE utf8_general_ci 校准规则

 

3、查看所有字符集和对应的校准规则
show character set;

MySQL--字符编码和字符集
 

二、解决方法:

1、插入数据的时候,先设置客户端插入字符集和数据库建表相同的字符集
eg:如果数据库表字符集是latinl,那么插入数据的时候也要是latinl
方法:set names latinl
insert into student value('飞东')

MySQL--字符编码和字符集
MySQL--字符编码和字符集
 

2、将sql语句放入文件中,使用source来执行这个文件,插入数据,则不会出现乱码,原理是和1一样的,只是放在文件中执行而已

方法:将下面两个语句放入一个新建文件中,如Mysql.sql

set names Latinl
insert into student value('飞东')
执行这个文件:source mysql.sql

MySQL--字符编码和字符集
 

3、从其他文件导入数据库(避免导入数据有中文乱码的问题)

将数据编码格式保存为utf-8(UTF8不要导入gbk,gbk不要导入UTF8)

set names utf8;
ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;  修改数据库的编码格式
ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;     修改表的编码格式
LOADLOCAL'C:\\utf8.txt'INTOTABLE tb_name;    从文件中导入数据库

 

4、永久修改默认客户端编码格式(修改my.cnf配置文件,针对MySQL 5.5版本以上)

MySQL--字符编码和字符集
MySQL--字符编码和字符集
 

5、永久修改默认服务端编码格式(修改my.cnf配置文件,针对MySQL 5.5版本以上)

MySQL--字符编码和字符集
MySQL--字符编码和字符集
修改完毕之后重启mysqld服务:service mysqld restart
 

三、常用命令

1、查看默认编码格式 show variables like "%char%";

MySQL--字符编码和字符集
MySQL--字符编码和字符集
MySQL--字符编码和字符集

character_set_client(客户端)、character_set_connection(连接)、character_set_results(结果) 三者字符集是一致的

 

2、修改数据库的编码格式
ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;  

 

3、修改表的编码格式
ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;  

 

4、通过ALTER 修改库或者表的字符集,只是对之后插入的数据有效,原来已经存在的数据无法修改,如果需要修改原来带有数据的字符集,只能通过把原来的数据导出来,再插入到新的已经修改过字符集的表(数据库)中。

 
 

四、建议

1、中英文环境,linux设置系统字符集为utf8,数据库服务端,客户端,数据库,表都是utf8字符集

 

2、无论是查寻还是插入,都先用set names utf8 先设置一下字符集

 

3、建议建数据库语句:

MySQL--字符编码和字符集
 

4、建议表语句:

MySQL--字符编码和字符集
  4、建议表语句:
  

您可能感兴趣的文档:

--结束END--

本文标题: MySQL--字符编码和字符集

本文链接: https://www.lsjlt.com/news/35007.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL--字符编码和字符集
    前言: 一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)  保证不出现乱码的思想:保证客户端、服务端...
    99+
    2022-10-18
  • Python字符集和字符编码详情
    目录前言字符集和字符编码小结前言 这一次我们分析一下Python的字符串,首先字符串是一个变长对象,因为不同长度的字符串所占的内存是不一样的;但同时字符串又是一个不可变对象,因为一旦...
    99+
    2022-11-11
  • 深入解析字符集和字符编码
    ...
    99+
    2022-10-18
  • Python字符集和字符编码是什么
    这篇文章主要介绍“Python字符集和字符编码是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python字符集和字符编码是什么”文章能帮助大家解决问题。首先计算机存储的基本单位是字节,由8个比...
    99+
    2023-06-30
  • MySQL中GBK字符集和UTF8字符编码的相关操作
    下面讲讲关于MySQL中GBK字符集和UTF8字符编码的相关操作,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL中GBK字符集和UTF8字符编码的相关操作这篇文章你一定...
    99+
    2022-10-18
  • MySQL解决字符集编码问题
    目录前言方法1:在创建数据库时,指定字符集方法2: 更改mysql的配置文件前言 MySQL的默认编码方式是 拉丁文,如果想要设置一些汉字的数据.可能会报错.分享一下我解决这个问题时的方法.1. 在创建数据库时,指定字符...
    99+
    2023-04-12
    MySQL解决字符集编码 字符集编码问题 MySQL字符集
  • mysql怎么修改表字符集编码
    mysql修改表字符集编码的操作步骤:借助Navicat for MySQL管理工具。下载安装并打开Navicat软件。点击“连接”按钮,输入ip地址、端口号、用户名及密码。连接数据库。连接成功后,选择要使用的数据仓库,右键选择“数据库属性...
    99+
    2022-10-15
  • Linux的字符集及编码
    Linux 字符集设置 查询 (1) 查看当前服务器字符集:  # locale  (2) 查看服务器支持的字符集:  # locale -a 修改linux系统字符集的方式有如下两种: (1) 直接设置变量的方式修改,命令如下两条命令: ...
    99+
    2023-09-02
    linux 服务器 运维
  • mysql 字符集乱码探究
    环境描述:青云的mysql实例的ip为:192.168.0.254,和青云的跳板主机,我们在跳板主机上安装了mysql服务,并通过下面方式连接mysql: ...
    99+
    2022-10-18
  • MySQL字符编码设置
    通过show variables like 'character_set%%';查看编码修改mysql的编码方式可以有以下几个:1.通过配置文件修改my.ini(windows下)或/etc/my.cnf(...
    99+
    2022-10-18
  • MySQL的字符集
    #1, 字符集相关的参数名和概念   MySQL的字符集设置比较自由。可以设置很多种组合,相关的变量和参数有:      (root@localhost)[sample3]> show global ...
    99+
    2022-10-18
  • mysql如何查询表的字符集编码
    这篇文章主要介绍了mysql如何查询表的字符集编码的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql如何查询表的字符集编码文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2022-10-19
  • 如何解决MySQL字符集编码问题
    这篇文章给大家分享的是有关如何解决MySQL字符集编码问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。项目中,用中断命令导入sql脚本,发现其报出编码错误,后来进过一番分析查询...
    99+
    2022-10-19
  • MySQL字符集编码问题怎么解决
    本文小编为大家详细介绍“MySQL字符集编码问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL字符集编码问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。方法1:在创建数据库时,指定字...
    99+
    2023-07-06
  • 字符编码
    计算机基础 文本编辑器存取文件的原理 1.打开编辑器就打开启动了一个进程,是在内存中,所以,用编码器编写的内容也都存放在内存中的,断电后数据丢失。 2.要想永久保存,需要点击保存按钮:编辑器把内存的数据拴到硬盘上。 3.早我们编写一个...
    99+
    2023-01-31
    字符
  • MySQL字符集乱码怎么办
    小编给大家分享一下MySQL字符集乱码怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言字符集是一套符号和编码的规则,不论...
    99+
    2022-10-18
  • mysql字符集修改
    本实验的环境:linux系统:cat /etc/redhat-release CentOS release 6.5 (Final)数据库环境(源码编译,多实例):select version();...
    99+
    2022-10-18
  • day08(字符编码,字符与字节,文件操
      一,复习 ''' 类型转换 1.数字类型:int() | bool() | float() 2.str与int: int('10') | int('-10') | int('0') | float('-.5') ...
    99+
    2023-01-31
    字符 字节 文件
  • Python中的字符串与字符编码
    Hello,这里是Token_w的博客,欢迎您的到来 今天文章讲解的是Python中的字符串与字符编码,其中有基础的理论知识讲解,也有实战中的应用讲解,希望对你有所帮助 整理不易,如对你有所帮助,希望能得到你的点赞、收藏支持。感谢 ...
    99+
    2023-08-30
    python android 开发语言
  • python字符编码
    近期接触到python的编码相关的东西,发现自己了解的不是太系统,故通过搜索资料做了一些总结。 字符编码 字符串也是一种数据类型,但是,字符串比较特殊的是还有一个编码问题。 我们知道,计算机内部,所有信息最终都是一个二进制值。每一个二进制位...
    99+
    2023-01-31
    字符 python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作