3

如何让 MariaDB 客户端使用 UTF-8?我对等效版本的 MySQL 没有这个问题。 我正在尝试在不SET NAMES通过客户端发布的情况下执行此操作。 我使用 cmd 行客户端和 php 的 mysqli 驱动程序获得 latin1。

PHP mysqli_get_charset:

print_r(mysqli_get_charset($link));
stdClass Object
(
    [charset] => latin1
    [collation] => latin1_swedish_ci
    [dir] => 
    [min_length] => 1
    [max_length] => 1
    [number] => 8
    [state] => 1
    [comment] => 
)

这是命令行客户端的输出:

echo "show variables like 'char%';" | mysql -u root -p

Variable_name   Value
character_set_client    utf8
character_set_connection        utf8
character_set_database  latin1
character_set_filesystem        binary
character_set_results   utf8
character_set_server    latin1
character_set_system    utf8
character_sets_dir      /usr/share/mysql/charsets/

这是我的 my.cnf 文件。

[client]
port            = 3306
socket          = /var/run/mysqld/mysqld.sock
default-character-set=utf8
[mysqld_safe]
socket          = /var/run/mysqld/mysqld.sock
nice            = 0
default-character-set=utf8
[mysqld]
user            = mysql
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
port            = 3306
basedir         = /usr
datadir         = /var/lib/mysql
tmpdir          = /tmp
lc-messages-dir = /usr/share/mysql
skip-external-locking
default-character-set  = utf8
default-collation      = utf8_general_ci
character_set_server   = utf8
collation_server       = utf8_general_ci
init_connect='SET NAMES utf8'
key_buffer              = 512M
max_allowed_packet      = 64M
thread_stack            = 192K
thread_cache_size       = 8
myisam-recover         = BACKUP
query_cache_limit       = 4M
query_cache_size        = 64M
expire_logs_days        = 10
max_binlog_size         = 100M
[mysqldump]
quick
quote-names
max_allowed_packet      = 64M
default-character-set=utf8
[mysql]
no-auto-rehash  # faster start of mysql but no tab completition
default_character_set=utf8
[isamchk]
key_buffer              = 128M
[client-server]
default-character-set=utf8
[client-mariadb]
default-character-set=utf8
!includedir /etc/mysql/conf.d/
4

2 回答 2

1

我解决了这个问题。我使用他们的 repo 和 apt-get 安装了 mariadb。一切似乎都很顺利。我使用命令service mysql restart和编码问题进行了这些非常慢的重启。我注意到有 2 个 mysqld 实例,我继续发送了一个 kill 命令,我不推荐 kill -9,常规 kill 工作得很好。然后做了一个service mysql restart,它开始很快,字符编码按预期工作。

于 2013-05-07T15:33:22.793 回答
1

问题是,无论如何你都不应该通过客户端发布。SET NAMES
因为这个命令是不够的,除了服务器你还必须设置客户端编码。这只能通过使用 API 函数来完成。SET NAMES因此,您应该在 PHP 脚本中通过msql(i)_set_charset()函数或 DSN设置客户端编码,而不是发出查询。

因此,请记住 - 更改默认编码不会使您摆脱在 PHP 中设置编码的必要性。

然而,utf-8作为默认值比latin1. my.ini因此,在[mysqld]部分下添加以下行

init-connect='SET NAMES utf8'
于 2013-04-13T05:40:33.937 回答