Mysql第一章 字符集

news2025/1/23 10:44:47

字符集修改

  • 一 在mysql5.7中输入汉字报错
  • 二 修改针对修改后创建的数据库,过去创建的数据库不算
  • 三 想要单独修改
  • 四 基本的mysql命令
  • 五 各级别的字符集

一 在mysql5.7中输入汉字报错

# 在5,7中,默认字符集为latin1,开发人员在数据库设计时,需要手动
# 将编码改成utf8,没有修改,就会出现迁移数据库时报错乱码的问题
#  

SHOW VARIABLES LIKE 'character%';
SHOW VARIABLES LIKE '%char%';
USE test1;
CREATE TABLE emp1(id INT,lname VARCHAR(15));
SELECT * FROM emp1;
INSERT INTO emp1(id,lname) VALUES (1,'Tom');
INSERT INTO emp1(id,lname) VALUES (2,'康师傅');

错误

1 queries executed, 0 success, 1 errors, 0 warnings

查询:nsert into emp1(id,lname) values (2,'康师傅')

错误代码: 1064
You have an error in your SQL syntax; 
check the manual that corresponds to your MySQL server version
for the right syntax to use near 'nsert into emp1(id,lname) values (2,'康师傅')' at line 1

执行耗时   : 0 sec
传送时间   : 0 sec
总耗时      : 0 sec

二 修改针对修改后创建的数据库,过去创建的数据库不算

改环境

vim /etc/my.cnf
systemctl restart  mysqld.service

vim时候,主要在表末尾加入

character_set_server=utf8

执行下面指令,得到一个表,证明类型修改成功

show variables like 'character_set_%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

执行下面指令,正面在修改配置环境之前创建的数据库,它的类型不会改变

mysql> show create database test3;
+----------+------------------------------------------------------------------+
| Database | Create Database                                                  |
+----------+------------------------------------------------------------------+
| test3    | CREATE DATABASE `test3` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+----------+------------------------------------------------------------------+

三 想要单独修改

mysql> alter database test1 character set 'utf8';
Query OK, 1 row affected (0.00 sec)

mysql> show create database test1;
+----------+----------------------------------------------------------------+
| Database | Create Database                                                |
+----------+----------------------------------------------------------------+
| test1    | CREATE DATABASE `test1` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+----------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> use test1;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> alter table emp1 convert to character  set 'utf8';
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> 

四 基本的mysql命令

create database test1;
use test1;
create table emp1(age int,name varchar(15));
insert into emp1(age, name) values (1,'康师傅');
mysql> select * from emp1;
+------+-----------+
| age  | name      |
+------+-----------+
|    1 | 康师傅    |
+------+-----------+



五 各级别的字符集

上一层默认决定下一层
服务器
数据库
表级别
列级别

utf8决定一个字符需要1到4个字节,
可能说三个字节就能满足大多数数据的存储需要,同时兼顾存储性能,因此默认是utf8mb3
但是一些特殊的字符需要四个字节,要用utf8mb4

mysql> show variables like '%character%'
    -> ;
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)
mysql> show charset;
+----------+---------------------------------+---------------------+--------+
| Charset  | Description                     | Default collation   | Maxlen |
+----------+---------------------------------+---------------------+--------+
| big5     | Big5 Traditional Chinese        | big5_chinese_ci     |      2 |
| dec8     | DEC West European               | dec8_swedish_ci     |      1 |
| cp850    | DOS West European               | cp850_general_ci    |      1 |
| hp8      | HP West European                | hp8_english_ci      |      1 |
| koi8r    | KOI8-R Relcom Russian           | koi8r_general_ci    |      1 |
| latin1   | cp1252 West European            | latin1_swedish_ci   |      1 |
| latin2   | ISO 8859-2 Central European     | latin2_general_ci   |      1 |
| swe7     | 7bit Swedish                    | swe7_swedish_ci     |      1 |
| ascii    | US ASCII                        | ascii_general_ci    |      1 |
| ujis     | EUC-JP Japanese                 | ujis_japanese_ci    |      3 |
| sjis     | Shift-JIS Japanese              | sjis_japanese_ci    |      2 |
| hebrew   | ISO 8859-8 Hebrew               | hebrew_general_ci   |      1 |
| tis620   | TIS620 Thai                     | tis620_thai_ci      |      1 |
| euckr    | EUC-KR Korean                   | euckr_korean_ci     |      2 |
| koi8u    | KOI8-U Ukrainian                | koi8u_general_ci    |      1 |
| gb2312   | GB2312 Simplified Chinese       | gb2312_chinese_ci   |      2 |
| greek    | ISO 8859-7 Greek                | greek_general_ci    |      1 |
| cp1250   | Windows Central European        | cp1250_general_ci   |      1 |
| gbk      | GBK Simplified Chinese          | gbk_chinese_ci      |      2 |
| latin5   | ISO 8859-9 Turkish              | latin5_turkish_ci   |      1 |
| armscii8 | ARMSCII-8 Armenian              | armscii8_general_ci |      1 |
| utf8     | UTF-8 Unicode                   | utf8_general_ci     |      3 |
| ucs2     | UCS-2 Unicode                   | ucs2_general_ci     |      2 |
| cp866    | DOS Russian                     | cp866_general_ci    |      1 |
| keybcs2  | DOS Kamenicky Czech-Slovak      | keybcs2_general_ci  |      1 |
| macce    | Mac Central European            | macce_general_ci    |      1 |
| macroman | Mac West European               | macroman_general_ci |      1 |
| cp852    | DOS Central European            | cp852_general_ci    |      1 |
| latin7   | ISO 8859-13 Baltic              | latin7_general_ci   |      1 |
| utf8mb4  | UTF-8 Unicode                   | utf8mb4_general_ci  |      4 |
| cp1251   | Windows Cyrillic                | cp1251_general_ci   |      1 |
| utf16    | UTF-16 Unicode                  | utf16_general_ci    |      4 |
| utf16le  | UTF-16LE Unicode                | utf16le_general_ci  |      4 |
| cp1256   | Windows Arabic                  | cp1256_general_ci   |      1 |
| cp1257   | Windows Baltic                  | cp1257_general_ci   |      1 |
| utf32    | UTF-32 Unicode                  | utf32_general_ci    |      4 |
| binary   | Binary pseudo charset           | binary              |      1 |
| geostd8  | GEOSTD8 Georgian                | geostd8_general_ci  |      1 |
| cp932    | SJIS for Windows Japanese       | cp932_japanese_ci   |      2 |
| eucjpms  | UJIS for Windows Japanese       | eucjpms_japanese_ci |      3 |
| gb18030  | China National Standard GB18030 | gb18030_chinese_ci  |      4 |
+----------+---------------------------------+---------------------+--------+
41 rows in set (0.00 sec)


客户端把查询的信息发给服务器处理的具体过程,需要经过一个编码的翻译再转码的过程

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

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

相关文章

Python用curve_fit进行多元拟合

文章目录 入门参数多元拟合 入门 scipy.optimize中,curve_fit函数可调用非线性最小二乘法进行函数拟合,例如,现在有一个高斯函数想要被拟合 y a exp ⁡ − ( x − b c ) 2 y a\exp-(\frac{x-b}{c})^2 yaexp−(cx−b​)2 则调用方法如下 …

Zookeeper源码分析——Follower和Leader状态同步源码

Follower和Leader状态同步源码 当选举结束后,每个节点都需要根据自己的角色更新自己的状态。选举出的Leader更新自己状态为 Leader,其他节点更新自己状态为 Follower Leader更新状态入口: leader.lead() Follower更新状态入口: f…

VUE3 学习笔记(九)使用富文本编辑器tinymce最新版

目录 1、安装相关依赖 2、下载中文包 3. 引入皮肤和汉化包 4. 封装组件:在src/components下新建TEditor.vue,并写入以下代码 5. 注册及使用组件 6. Tinymce 版本(截至2023-04-18) 1、安装相关依赖 npm install tinymce -S npm install ti…

python+vue小型公司人事企业员工培训报名管理系统

该系统主要实现了公告信息管理、个人考勤管理、培训信息管理、员工管理、员工工资管理等主要模块功能。具体功能如下所示: 1. 公告信息管理:查看公告标题、公告类型、公告图片、发布日期等一系列信息。 2. 个人考勤管理:查看考勤名称、员工工…

Springboot整合Quartz定时任务框架(Spring解决方案)

目录 前言 介绍 集成 POM依赖 基础配置 1、配置数据源 2、配置JOB实例与触发器 3、配置SchedulerJobFactory 4、配置SchedulerFactoryBean 业务集成 job编写 接口编写 接口实现 前言 系统现在有定时任务触发业务场景的需求,并且频率及次数不固定&…

【案例教程】FVCOM流域、海洋水环境数值模拟方法及实践技术应用

近年来,随着人类活动产生营养负荷的增加,流域、海洋生态系统面临严重威胁。近岸水质数值模是近岸水环境保护的有效工具,已经应用于近岸水环境污染控制、水质规划管理中。FVCOM在近岸水环境模拟方面具有一定优势,如采用非结构化三角…

王道计组(23版)2_数据的表示和运算

1.数制和编码 十进制转换为二进制: 原码: [0]原0,0000 [-0]原1,0000 -1无法表示 补码: 按位取反,末位加1 [0.0000]补[-0.0000]补0.00000 反码: 按位取反 [0]反0,0000 [-0]反1,1111 移码: 与补码仅符号位…

从前端角度快速理解Transformer

从前端角度快速理解Transformer Transformer的三步曲从前端角度(SEO和TDK)理解TransformerSEO与TDK一个例子来理解 总结 声明:本文为原创,未经同意请勿转载或爬取,感谢配合😄 chatGPT今年年初的时候是非常火…

操作系统实验一 并发程序设计

1.实验目的 掌握Linux环境下,多进程之间并发程序设计方法,并通过程序的运行结果来验证分时系统和并发程序设计的优越性。 2.实验要求 熟悉Linux操作系统子进程创建方法以及任务执行时间测量方法 3.实验内容 在单进程(单用户、单任务&#xff…

【MYSQL索引失效的场景有哪些】

创建一张表:id为主键(primary key)name为普通建(index) 插入数据: 用主键索引查询: 用普通建索引查询 对于执行计划,参数有: possible_keys 字段表示可能用到的索引&am…

KMM初探与编译过程详解

本文字数:22817字 预计阅读时间:58分钟 简介 KMM, 即Kotlin Multiplatform Mobile,是由Kotlin发布的移动端跨平台框架。相比于其他跨平台框架,KMM是原生UI逻辑共享的理念,共享重复逻辑性的工作来提升开发效…

Maven配置国内源以及jar下载失败处理详解

目录 1,配置Idea的Maven xml文件不存在: xml文件存在: 2,重新下载jar包 3,注意事项总结 1,配置Idea的Maven 需要配置的项目有两个,一个是当前项目,一个是新项目: 打…

抖音账号矩阵搭建管理获客系统

抖音矩阵号管理系统是一款企业矩阵运营管理工具,能够有效地帮助企业管理多个矩阵账号,并实现批量管理。在短视频矩阵系统中,自动获客工具和智能AI的帮助下,一个人也能轻松地管理多个账号。 一、矩阵账号管理: 首先&a…

leetCode算法第三天

继续练习leetcode中关于字符串的算法题,越练越觉得自己编码思想还很欠缺,继续努力。 文章目录 有效的括号括号生成串联所有单词的子串最长有效括号 有效的括号 leetcode链接:https://leetcode.cn/problems/valid-parentheses/ 解题思路&…

SPI协议

SPI数据接口 SPI(Serial Peripheral Interface)串行外设接口的简称,它是一种同步全双工通信协议。有 3根或者 4根数据线组成,包括 CLK、SOMI、SIMO、STE: CLK为时钟线,由主机控制输出。 SOMI…

国产数字温度传感芯片M117 Pin to Pin替代PT100和PT1000

高精度数字温度传感芯片 - M117,可Pin to Pin替代PT100/PT1000,且具功能差异化优势,支持行业应用的定制化需求。高测温精度0.1℃,用户无需进行校准。芯片感温原理基于CMOS半导体PN节温度与带隙电压的特性关系,经过小信…

电脑开机进不了系统卡在加载界面怎么办?

电脑开机进不了系统卡在加载界面怎么办?有用户电脑弹出需要进行系统更新,不小心点到了系统更新的选项。因为自己不想进行系统更新,所以马上将电脑关机了。但是关机之后却发现系统一直卡在开机的界面中,无法进入桌面中了。那么这个…

如何在Anaconda下安装pytorch(conda安装和pip安装)

前言 文字说明 本文中标红的,代表的是我认为比较重要的。 版本说明 python环境配置:jupyter的base环境下的python是3.10版本。CUDA配置是:CUDA11.6。目前pytorch官网提示支持的版本是3.7-3.9 本文主要用来记录自己在安装pytorch中…

乙肝80%以上由妈妈传给孩子 5岁以下治愈率超六成

中国是乙肝大国。目前,乙肝病毒感染人数仍超过7000万。通过医务人员多年的努力,母婴传播感染率明显下降。到目前为止,已降至0.3%左右。每年仍有5万名儿童感染乙肝病毒。目前,儿童慢性乙肝仍在180万左右,绝对数仍是世界…

Node【模块系统】

文章目录 🌟前言🌟Nodejs模块系统🌟为什么需要模块化🌟什么是Nodejs模块🌟Nodejs模块分类🌟文件模块的分类🌟调用内置模块🌟调用文件模块 🌟Nodejs模块使用🌟…