thinkphp5 读取mysql中文数据乱码
乱码原因
Tp5默认的PDO连接mysql方式在某种特殊环境下没有默认utf8
解决方式
写在数据库datebse.php配置里增加连接配置信息
‘params’ => [
\PDO::MYSQL_ATTR_INIT_COMMAND => ‘SET NAMES utf8’,
\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true
],
即:
<?php
return [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '127.0.0.1',
// 数据库名
'database' => 'test',
// 用户名
'username' => 'root',
// 密码
'password' => 'password',
// 端口
'hostport' => '',
// 连接dsn
'dsn' => '',
// 数据库连接参数 注意:此处为增加的 设置默认编码utf8
'params' => [
\PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => true
],
// 数据库编码默认采用utf8
'charset' => 'utf8',
// 数据库表前缀
'prefix' => '',
// 数据库调试模式
'debug' => true,
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
// 是否严格检查字段是否存在
'fields_strict' => true,
// 数据集返回类型
'resultset_type' => 'array',
// 自动写入时间戳字段
'auto_timestamp' => false,
// 时间字段取出后的默认时间格式
'datetime_format' => 'Y-m-d H:i:s',
// 是否需要进行SQL性能分析
'sql_explain' => false,
];
最后别问我为什么,好使就行。