mysql没有安装utf8的字符集_mysql提供'无法初始化字符集UTF-8(路径:/ usr/share/mysql/charsets /)'错误,没有utf8.xml文件...

我的debian盒上有一个本地服务器。它是最新的,有PHP和MySQL安装和运行顺利。 我一直在寻找,了解多一点的mysqli的,当我尝试下面的代码:

$db = new mysqli('localhost', 'userdb', 'pwuserdb', 'db');

if(!$db->set_charset('utf-8')) {

printf("Error setting the character set utf-8: %s\n", $db->error);

} else {

printf("Current character set is: %s\n", $db->character_set_name());

}

print_r($db->get_charset());

?>

我,出乎我的意料,得到了以下信息,访问该页面时: Error setting the character set utf-8: Can't initialize character set utf-8 (path: /usr/share/mysql/charsets/) stdClass Object ([charset] => latin1 [collation] => latin1_swedish_ci [dir] => [min_length] => 1 [max_length] => 1 [number] => 8 [state] => 801 [comment] => cp1252 West European)

我心想,这是合乎逻辑的,因为我没有设置UTF-8作为MySQL的标准字符集,所以我在my.cnf文件如下设置完成:

为[mysqld]

default-character-set=utf8

为[client]

default-character-set=utf8

我还记录到MySQL从命令行跑从命令行 ALTER DATABASE db CHARSET=utf8;

我还重新加载的MySQL,以及apache的。 当寻找的东西是如何在mysql中去,几乎一切看起来正常的:

mysql> 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不能找到UTF8文件的事实,我在/usr/share/mysql/charsets/文件夹查了utf8.xml文件没有一个。 在这个目录下的Index.xml文件中提到了utf8,但是我想这个问题来自xml文件在目录中丢失的事实。

仅供参考,我的系统区域设置都是UTF8(en和pl),我不明白为什么utf8.xml文件不在目录中,因为我没有在这个目录或其内容中玩笑在所有。

欢迎任何想法/建议/建议。

预先感谢您!

干杯!

2012-07-13

Iam Zesh

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值