怎么修改mysql数据库的字符集

怎么修改mysql数据库的字符集,第1张

1

如果没有配置好cmd里面的mysql 环境变量,那就在系统高级设置那儿进行MySQL的环境变量设置。

2

win+R,调出“运行”,输入cmd,回车

3

登录数据库,

4

查看数据库

5

查看数据库字符编码

6

通过MySQL命令行修改:(编码可选)

mysql> set character_set_client=utf8;

mysql> set character_set_connection=utf8;

mysql> set character_set_database=utf8;

mysql> set character_set_results=utf8;

mysql> set character_set_server=utf8;

mysql> set character_set_system=utf8;

mysql> set collation_connection=utf8;

mysql> set collation_database=utf8;

mysql> set collation_server=utf8;

7

当然还有:

修改数据库的字符集mysql>use mydb

mysql>alter database mydb character set utf8;

8

创建数据库指定数据库的字符集

mysql>create database mydb character set utf8;

我来给你做一个综合解释吧。

在正常情况下。

PHP脚本 HTML 已经浏览器 然后就是数据库。

都有自己的字符集。何谓字符集。我想你如果是一个真正想热衷于学PHP

那么你应该花一定的时间去了解一下字符集的问题。

因为无论你以后做什么项目开发什么网站都是要牵涉到字符集。

就好比我做第一个项目。因为字符集搞的死去活来。

好进入正题。怎么解决问题呢?

1PHP的字符集。一般PHP网页的是嵌套在html页面以内。那么如果在没有冲突的情况下可以使用

header方面设置。比如<php header >

2HTML的字符集,一般是网页的优先字符集,这个问题是牵涉到你的网站是什么定位,比如:你的网站仅仅适合国内的客户。那么用gbk 或者gb2312如果想老外也开凑凑热闹的话,就用utf-8至于怎么设置这个字符集,你可以在<meta>这个标记中看到。

3数据库的问题。mysql_query("set names gbk"); 这句话意思就是说,在 *** 作数据库的时候已这个字符集去读写。当然这个字符集要对应你的页面的字符集哦。

4浏览器。浏览器的问题是最万恶的,因为每个浏览器默认的是gb2312当然不同的浏览器是不同的。所以要想成为一名优秀的程序员,写出优质的代码。你还得去了解每个浏览器的差别。当然目前是不需要的,当然这个问题你慢慢学习。写代码的过程中会慢慢了解到的。

你要做的就是将所有使用字符集确保一致性

问题就这些吧,如果有什么问题可以继续问哦。凡是对PHP有热情的人。我都会尽全力帮一下。哈哈。因为这个加物以类聚。还有这个内容绝对不是复制粘贴的。

首先这是我一开始的Ubuntu 下MySQL默认字符集(下图),在Java中输入中文到数据库中全是乱码问号,MySQL不识别,是因为MySQL默认的字符集是latin1(ISO_8859_1)不是utf8的字符集。

修改方法:

1打开mycnf文件进行修改(这里注意下,MySQL版本是55以上的,以下版本应该也通用,具体没有测试过,但在55以上的绝对可行)

sudo gedit /etc/mysql/mycnf

2在[mysqld]下添加如下代码(对于55以上版本,[mysqld]的default字符集设置已经是遗弃的参数,可以使用这几个,具体查看相应版本的手册)

character-set-server=utf8

collation-server=utf8_general_ci

skip-character-set-client-handshake

3退出重启mysql服务

sudo service mysql restart

4进入mysql查看字符集

mysql> show variables like 'collation_%';

mysql> show variables like 'character_set_%';

解问题一

如果表包含在数据库中,即数据库表,可以在该表的“表设计器”中,该字符型字段的“输入掩码”文本框中输入与字段宽度等宽位数的“9”,比如字段宽度为5,则输入掩码为“99999”。

解问题二

这里有个概念,如果 INDEX 的<索引表达式>是单个字段

1、数值型字段,按照数值的大小升序排列

2、字符型字段,按照字符的ASCII值的大小升序排列

3、日期或日期时间型字段,按照日期的远近,从远到近排列

如果 INDEX 的<索引表达式>中包含多个字段,那么首先必须要能求出该表达式的值,然后才能做到按什么顺序排列,为了简化讨论,略过日期或日期时间型,因为日期或日期时间型必能通过函数转换成数值型或字符型数据

1、如果这多个字段都是数值型,则按照索引表达式的数值运算的值的大小升序排列

2、如果这多个字段都是字符型,则各字段联接(+或-)后,按照联接的顺序各字段依字符串的大小(按照ASCII)升序排列

3、如果这多个字段中有数值型也有字符型,则索引表达式应将其统一到同一数据类型。

举例:设表T1DBF,字段C1、C2为数值型,字段C3、C4为字符型

按C1+C2的和升序排列

INDEX ON C1+C2 TO T1

字段C3升序,相同时C4升序

INDEX ON C3+C4 TO T2

字段C1升序,相同时C2升序

INDEX ON STR(C1)+STR(C2) TO T3 && 将C1、C2都转成字符型,以字符串大小排列

字段C1升序,相同时C3升序

INDEX ON STR(C1)+C3 TO T4 && 将C1转成字符型,以字符串大小排列

字段C3升序,相同时C4降序

INDEX ON C3+STR(127-ASC(C4)) TO T5 && 127为ASCII的最大值

字段C1降序,相同时C3升序

INDEX ON STR(999-C1)+C3 TO T6 && 假设数值型字段C1的宽度为3位,999为该字段允许的最大值

检查当前数据库编码。

使用语句:

show variables like ‘%character%’;

show variables like’%collation%’;

如果不是以上情况,需要将mysql编码设置为utf-8。具体步骤如下:

如果安装mysql时安装了“MySql Sever Instance Configuration Wizard”,则只需要启动该程序进行相应设置即可。如下面截图中所描述,需要将默认编码设置为utf8

如果没有该程序,需要手动修改mysql编码。

1、 编辑MySql的配置文件

MySql的配置文件Windows下一般在系统目录下或者在MySql的安装目录下名字叫myini,可以搜索,Linux下一般是 /etc/mycnf

--在 [mysqld] 标签下加上以下内容:

default-character-set = utf8

character_set_server = utf8

注意:如果此标签下已经存在“default-character-set=GBK”类似的内容,只需修改即可。

--在 [mysql] 标签下加上一行

default-character-set = utf8

--在 [mysqlserver]标签下加上一行

default-character-set = utf8

--在 [mysqld_safe]标签下加上一行

default-character-set = utf8

--在 [client]标签下加上一行

default-character-set = utf8

2、 重新启动MySql服务

Windows可在服务管理器中 *** 作,也可使用命令行:

net stop mysql 回车

net start mysql 回车

服务名可能不一定为mysql,请按自己的设置

Linux下面可是用 service mysql restart

如果出现启动失败,请检查配置文件有没有设置错误

3、 查看设置结果

登录MySql命令行客户端:打开命令行

mysql –uroot –p 回车

输入密码

进入mysql后 执行 :show variables like "% character %";

另外:

建立数据库时可以使用以下命令:

create database app_relation character set utf8;

use app_relation;

source app_relationsql;

修改数据库编码的命令为:

alter database app_relation character set utf8;

新建一个模板,比如

template_utf8

,设置好utf-8以及plpgsql之类的lang还有插件,从这个数据库新建就全是uft-8了。

如果是更改的话,需要先把数据库导出为sql,

再新建,而后导入。导入前,修改sql里的create

语句,指定字符集。有汉字的话,另存为utf-8的编码,再导入。

创建数据库的时候,直接指定数据库的字符集,之后再该数据库中创建表的时候就不用再指定了,所有创建的表都是跟数据库字符集一样的。列如:create database \\'dbname\\' default character set utf8;

以上就是关于怎么修改mysql数据库的字符集全部的内容,包括:怎么修改mysql数据库的字符集、php创建mysql数据库时候如何设置字符集、mysql5.5怎么更改数据库默认字符集等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9564132.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存