【ThinkPHP入门学习】ThinkPHP连接数据库乱码问题

ThinkPHP5 通过PDO 连接MySQL数据库,出现读取中文的内容,乱码问题,各种问号???

乱码当然是编码不一致的问题,解决问题的一个办法是:

在application/database.php添加一个编码选项,在params配置里面添加

PDO::MYSQL_ATTR_INIT_COMMAND => ‘SET NAMES utf8’

详细配置如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
return [
'type' => 'mysql',
'hostname' => '127.0.0.1',
'database' => 'xxx',
'username' => 'xxx',
'password' => 'xxxxx',
'hostport' => '3306s',
'dsn' => '',
'params' => [
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
],
'charset' => 'utf8',
'prefix' => '',
'debug' => true,
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
// 自动读取主库数据
'read_master' => false,
// 是否严格检查字段是否存在
'fields_strict' => true,
// 数据集返回类型
'resultset_type' => 'array',
// 自动写入时间戳字段
'auto_timestamp' => false,
// 时间字段取出后的默认时间格式
'datetime_format' => 'Y-m-d H:i:s',
// 是否需要进行SQL性能分析
'sql_explain' => false,
];
坚持原创技术分享,谢谢鼓励我继续创作!