1、查看字符集相关变量
mysql> show variables like 'character%';
+————————–+——————————-+ | Variable_name | Value | +————————–+——————————-+ | character_set_client | latin1 | | character_set_connection | latin1 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | latin1 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | c:\wamp\mysql\share\charsets\ | +————————–+——————————-+
2、字符集转换过程
客户端——–字符集转换器———–服务
gbk ————gbk-utf8-utf8———-utf8
gbk————-gbk-gbk-utf8———-utf8
客户端要告诉服务端使用的编码是什么,然后没有直接告诉服务器而告诉“转换器”
字符集转换器收到客户端信息后查看服务器是什么编码,然后将客户端传来的字符集转换成服务器设置的字符集
服务器向客户端发送信息时也是先告诉“转换器”
3、字符集变量解释
character_set_client
客户端字符集,连接mysql的客户端程序的字符集,该变量告诉转换器客户端发送的字符集。
character_set_connection
转换器转换要转换成的字符集
character_set_server
服务端使用的字符集,存入数据时使用的字符集
character_set_results
查询的结果是什么编码
推论:什么时候会出现乱码
1:client 什么与实际不符,微软命令提示符默认是gbk,如果设置成utf8就会出现乱码
2:results与客户端页面不符的时候
什么时候会丢失数据
connection和服务器的字符集比client小时,会丢失数据,比如客户端是utf8而转换器是gbk
当客户端是utf8 而服务端是 gbk时要设置
set character_set_client=utf8
set character_set_connection=gbk/utf8 这里设置什么都可以,因为最终转换器会根据服务器的类型进行转换
set character_set_results=utf8
4、设置字符集变量
set names utf8 进入mysql设置所用的字符集
在my.conf中添加
[client] default-character-set=utf8 [mysqld] default-character-set=utf8
5.修改mysql字符集
将latin1字符集的数据库修改成gbk字符集的数据库的过程
(1)、导出表结构
mysqldump -uroot -p –default-character-set=gbk -d DATABASE_NAME > createtable.sql
–default-character-set=gbk 表示以什么字符集连接
-d 表示只导出表结构,不导出数据
(2)、修改createtable.sql文件中的表结构定义的字符集为新字符集
(3)、导出所有记录
mysqldump -uroot -p –quick –no-create-info –extend-insert –default-character-set DATABASE_NAME > data.sql
–quick:改讯息用于转储大的表。它强制mysqldump从服务器一次一行的检索表中的行二不是检索所有行,并在输出钱将它缓存到内存中
–extended-insert:使用包括几个values列表的多行insert语法。这样转储文件更小,重载文件时可以加速插入
–no-create-info:不重新创建每个转储表的create table 语句
–default-character-set=latin1:安装原有的字符集导出所有数据,这样导出的文件中,所有中文都是可见的,不会保存成乱码
(4)、带宽data.sql,将set names latin1 修改成set names gabk
(5)、使用新的字符集创建新的数据库
create database DATABASE_NAME default charset gbk;
(6)、创建表,执行createtable.sql
mysql -uroot -p DATABASE_NAME < createtable.sql
(7)、导入数据,执行data.sql
mysql -uroot -p DATABASE_NAME < data.sql

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

SublimeText3汉化版
中文版,非常好用

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中