PHP数据库应用建议

  • 2022-07-15 16:28:34

保持独立的读写连接

开始就创建两个数据库连接,一个用于读取,一个用于写入.
如果只有一个服务器就将它们设置为相同.之后进行主从的时候,将写入指向主服务器,将读取指向从服务器
将update,insert.delete归为写入连接,
将select归为读取连接

默认使用utf8(多字节unicode)字符集

在my.cnf中加入以下配置,强制所有新的数据库,表和文本字段默认采用utf8
[mysqld]
#使用utf8_general_ci 速度较快,除非你要支持特别的语言用utf8_unicode_ci   
collation_server = utf8_general_ci
character_set_server=utf8
#告诉服务器不执行与客户端的字符集协商.可以确保所有客户端和连接都设置采用的utf8.之后连接就不需要set names utf8
skip-character-set-client-handshake

扩展
1、utf8_unicode_ci 和 utf8_general_ci 对中、英文来说没有实质的差别;
2、utf8_general_ci 校对速度快,但准确度稍差;
3、utf8_unicode_ci 准确度高,但校对速度稍慢;
4、如果应用有德语、法语或者俄语,请一定使用utf8_unicode_ci;否则 utf8_general_ci 就够了,到现在也没发现问题;

参考

高性能PHP应用开发

猜你喜欢