MySQL服务端编码设置

数据库 MySQL
安装完mysql,启动后发现服务器默认使用的是lat1编码。那么我们怎么去设置呢?下文详细的介绍了具体的操作和查看。

安装完mysql,启动后发现服务器默认使用的是lat1编码。

具体操作和查看过程如下:

启动方式:/etc/init.d/mysql.server start

效果:

Database changed
mysql> status
--------------
mysql Ver 14.12 Distrib 5.0.77, for redhat-linux-gnu (x86_64) using readline 5.1

Connection id: 8
Current database: demodb
Current user: root@localhost
SSL: Not in use
Current pager: stdout
Using outfile: ''
Using delimiter: ;
Server version: 5.5.21 MySQL Community Server (GPL)
Protocol version: 10
Connection: Localhost via UNIX socket
Server characterset: latin1
Db characterset: utf8
Client characterset: latin1
Conn. characterset: latin1
UNIX socket: /var/lib/mysql/mysql.sock
Uptime: 33 sec

Threads: 7 Questions: 137 Slow queries: 0 Opens: 83 Flush tables: 1 Open tables: 76 Queries per second avg: 4.151
--------------

mysql>

启动方式: /etc/init.d/mysql.server start --character-set-server=utf8

效果:

mysql> use demodb;
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> status;
--------------
mysql  Ver 14.12 Distrib 5.0.77, for redhat-linux-gnu (x86_64) using readline 5.1

Connection id:        4
Current database:    demodb
Current user:        root@localhost
SSL:            Not in use
Current pager:        stdout
Using outfile:        ''
Using delimiter:    ;
Server version:        5.5.21 MySQL Community Server (GPL)
Protocol version:    10
Connection:        Localhost via UNIX socket
Server characterset:    utf8
Db     characterset:    utf8
Client characterset:    latin1
Conn.  characterset:    latin1
UNIX socket:        /var/lib/mysql/mysql.sock
Uptime:            1 min 15 sec

Threads: 4  Questions: 131  Slow queries: 0  Opens: 84  Flush tables: 1  Open tables: 77  Queries per second avg: 1.746
--------------

mysql>

这种方式,在每次启动的时候都需要指定编码参数。否则服务器就使用的是系统默认的lat1编码。

另外一种方法是:

mysql>set character_set_server=utf8;

这种方法我也试了,不行,再重新登录客户端后,就又恢复了原来的编码。理由很简单,系统启动的时候用的不是utf8编码。

一劳永逸的办法,就是通过修改配置文件实现.

# vim /etc/my.cnf

内容如下:

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql

#添加下面的红字内容

character-set-server=utf8

# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1


[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

原文链接:http://www.blogjava.net/zhyiwww/archive/2012/03/01/371055.html

【编辑推荐】

  1. MySQL源码学习:MDL字典锁
  2. MySQL Cluster开发环境简明部署
  3. MySQL的四种不同查询的分析
  4. 甲骨文推出MySQL集群7.2
  5. MySQL内存表的特性与使用介绍
责任编辑:林师授 来源: zhyiwww的博客
相关推荐

2016-03-18 09:04:42

swift服务端

2010-11-19 14:22:04

oracle服务端

2023-03-06 08:01:56

MySQLCtrl + C

2013-03-25 10:08:44

PHPWeb

2023-04-03 08:13:05

MySQLCtrl + C

2010-08-03 09:59:30

NFS服务

2016-11-03 09:59:38

kotlinjavaspring

2021-05-25 08:20:37

编程技能开发

2010-02-24 15:42:03

WCF服务端安全

2010-03-19 18:17:17

Java Server

2009-08-21 15:22:56

端口侦听

2022-12-29 08:56:30

监控服务平台

2010-03-18 18:09:36

Java Socket

2021-04-26 13:20:06

Vue服务端渲染前端

2023-08-08 08:17:23

VasDolly服务端参数

2011-09-09 09:44:23

WCF

2009-08-21 16:14:52

服务端与客户端通信

2009-08-21 15:59:22

服务端与客户端通信

2024-03-06 14:58:52

客户端微服务架构

2009-08-21 15:36:41

服务端与客户端
点赞
收藏

51CTO技术栈公众号