php+mysql开发中的经验与常识小结


Posted in PHP onMarch 25, 2019

本文总结了php+mysql开发中的经验与常识。分享给大家供大家参考,具体如下:

一、基础规范

(1)尽量使用 InnoDB 存储引擎

支持事务、行级锁、并发性能更好,CPU 及内存缓存页优化得当,资源利用率更高

(2)必须使用 UTF8 字符集

无需转码,无乱码风险

(3)数据表、数据字段必须加入中文注释

N 年后谁知道这个 r1,r2,r3 字段是干嘛的

(4)尽量不要使用存储过程、视图、触发器、Event

高并发大数据的互联网业务,架构设计思路是“解放数据库 CPU,将计算转移到服务层”,并发量大的情况下,这些功能很可能将数据库拖死,业务逻辑放到服务层具备更好的扩展性,能够轻易实现“增机器就加性能”。数据库擅长存储与索引,CPU 计算尽量挪到上层

(5)禁止存储大文件或者大照片

不要让数据库做它不擅长的事情。大文件和照片存储在文件系统(使用上传服务),数据库里存 URI

二、命名规范

(6)库名、表名、字段名:小写,下划线风格,不超过 32 个字符,必须见名知意,禁止拼音英文混用

(7)表名简洁清晰,非唯一索引名 idx_xxx,唯一索引名 uniq_xxx

三、表设计规范

(8)单实例表数目必须小于 500

(9)单表列数目最好小于 30

(10)表必须有主键,例如自增主键

a)主键递增,数据行写入可以提高插入性能,可以避免 page 分裂,减少表碎片,提升空间和内存的使用

b)主键要选择较短的数据类型, Innodb 引擎普通索引都会保存主键的值,较短的数据类型可以有效的减少索引的磁盘空间,提高索引的缓存效率c) 无主键的表删除,在 row 模式的主从架构,会导致备库卡住

(11)禁止不要使用外键,如果有外键完整性约束,需要应用程序控制

外键会导致表与表之间耦合,update 与 delete 操作都会涉及相关联的表,十分影响 sql 的性能,甚至会造成死锁。高并发情况下容易造成数据库性能,大数据高并发业务场景数据库使用以性能优先

四、字段设计规范

(12)必须把字段定义为 NOT NULL 并且提供默认值

a)null 的列使索引/索引统计/值比较都更加复杂,对 MySQL 来说更难优化
b)null 这种类型 MySQL 内部需要进行特殊处理,增加数据库处理记录的复杂性;同等条件下,表中有较多空字段的时候,数据库的处理性能会降低很多
c)null 值需要更多的存储空间,无论是表还是索引中每行中的 null 的列都需要额外的空间来标识
d)对 null 的处理时候,只能采用 is null 或 is not null,而不能采用=、in、<、<>、!=、 not in 这些操作符号。如:where name!='cuiyang',如果存在 name 为 null 值的记录,查询结果就不会包含 name 为 null 值的记录

(13)禁止使用 TEXT、BLOB 类型

会浪费更多的磁盘和内存空间,非必要的大量的大字段查询会淘汰掉热数据,导致内存命中率急剧降低,影响数据库性能

(14)避免使用小数存储货币

使用整数存储,小数容易导致钱对不上

(15)必须使用 varchar(20)存储手机号

  • a)涉及到区号或者国家代号,可能出现+-()
  • b)手机号会去做数学运算么?
  • c)varchar 可以支持模糊查询,例如:like“138%”

(16)禁止使用 ENUM,可使用 TINYINT 代替

  • a)增加新的 ENUM 值要做 DDL 操作
  • b)ENUM 的内部实际存储就是整数,你以为自己定义的是字符串?

五、索引设计规范

(17)单表索引建议控制在 5 个以内

(18)单索引字段数不允许超过 5 个

字段超过 5 个时,实际已经起不到有效过滤数据的作用了

(19)禁止在更新十分频繁、区分度不高的属性上建立索引

  • a)更新会变更 B+树,更新频繁的字段建立索引会大大降低数据库性能
  • b)“性别”这种区分度不大的属性,建立索引是没有什么意义的,不能有效过滤数据,性能与全表扫描类似

(20)建立组合索引,必须把区分度高的字段放在前面

能够更加有效的过滤数据

六、SQL 使用规范

(21)禁止使用 SELECT *,只获取必要的字段,需要显示说明列属性

  • a)读取不需要的列会增加 CPU、IO、NET 消耗
  • b)不能有效的利用覆盖索引
  • c)使用 SELECT *容易在增加或者删除字段后出现程序 BUG

(22)禁止使用 INSERT INTO t_xxx VALUES(xxx),必须显示指定插入的列属性

容易在增加或者删除字段后出现程序 BUG

(23)禁止使用属性隐式转换

SELECT uid FROM t_user WHERE phone=13812345678

 会导致全表扫描,而不能命中 phone 索引

(24)避免在 WHERE 条件的属性上使用函数或者表达式

SELECT uid FROM t_user WHERE from_unixtime(day)>='2017-02-15'

会导致全表扫描正确的写法是:

SELECT uid FROM t_user WHERE day>= unix_timestamp(‘2017-02-15 00:00:00')

(25)避免负向查询,禁止%开头的模糊查询

a)负向查询条件:NOT、!=、<>、!<、!>、NOT IN、NOT LIKE 等,会导致全表扫描
b)%开头的模糊查询,会导致全表扫描

(26)避免大表使用 JOIN 查询及子查询

会产生临时表,消耗较多内存与 CPU,极大影响数据库性能

(27)避免使用 OR 条件,尽量改为 IN 查询

旧版本 Mysql 的 OR 查询是不能命中索引的,即使能命中索引,数据库也需要耗费更多的 CPU 帮助实施查询优化

(28)应用程序必须捕获 SQL 异常,并有相应处理

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
PHP XML数据解析代码
May 26 PHP
PHP5中虚函数的实现方法分享
Apr 20 PHP
使用 PHPMAILER 发送邮件实例应用
Nov 07 PHP
CodeIgniter中使用cookie的三种方式详解
Jul 18 PHP
php对关联数组循环遍历的实现方法
Mar 13 PHP
最准确的php截取字符串长度函数
Oct 29 PHP
PHP中addslashes与mysql_escape_string的区别分析
Apr 25 PHP
PHP简单判断手机设备的方法
Aug 23 PHP
完美解决Thinkphp3.2中插入相同数据的问题
Aug 01 PHP
php实现websocket实时消息推送
Mar 30 PHP
php计数排序算法的实现代码(附四个实例代码)
Mar 31 PHP
宝塔面板出现“open_basedir restriction in effect. ”的解决方法
Mar 14 PHP
PHP设计模式之抽象工厂模式实例分析
Mar 25 #PHP
PHP设计模式之简单工厂和工厂模式实例分析
Mar 25 #PHP
PHP实现无限极分类的两种方式示例【递归和引用方式】
Mar 25 #PHP
详解PHP神奇又有用的Trait
Mar 25 #PHP
PHP自动载入类文件函数__autoload的使用方法
Mar 25 #PHP
PHP生成短网址的思路以及实现方法的详解
Mar 25 #PHP
PHP错误提示It is not safe to rely on the system……的解决方法
Mar 25 #PHP
You might like
phpMyAdmin 链接表的附加功能尚未激活问题的解决方法(已测)
2012/03/27 PHP
利用PHP内置SERVER开启web服务(本地开发使用)
2020/01/22 PHP
js检测客户端不是firefox则提示下载
2007/04/07 Javascript
一个封装js代码-----展开收起效果示例
2013/07/03 Javascript
Jquery仿淘宝京东多条件筛选可自行结合ajax加载示例
2013/08/28 Javascript
javascript作用域问题实例分析
2015/07/13 Javascript
JS优化与惰性载入函数实例分析
2017/04/06 Javascript
JS条形码(一维码)插件JsBarcode用法详解【编码类型、参数、属性】
2017/04/19 Javascript
Node.js中流(stream)的使用方法示例
2017/07/16 Javascript
Koa2微信公众号开发之本地开发调试环境搭建
2018/05/16 Javascript
详解nodejs解压版安装和配置(带有搭建前端项目脚手架)
2018/12/06 NodeJs
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
2019/06/17 Javascript
vue实现的封装全局filter并统一管理操作示例
2020/02/02 Javascript
js对象简介与基本用法示例
2020/03/13 Javascript
JavaScript 俄罗斯方块游戏实现方法与代码解释
2020/04/08 Javascript
JavaScript实现猜数字游戏
2020/05/20 Javascript
使用Python的urllib2模块处理url和图片的技巧两则
2016/02/18 Python
Python数据结构与算法之使用队列解决小猫钓鱼问题
2017/12/14 Python
Python3计算三角形的面积代码
2017/12/18 Python
Scrapy基于selenium结合爬取淘宝的实例讲解
2018/06/13 Python
详解Python使用Plotly绘图工具,绘制甘特图
2019/04/02 Python
Django 缓存配置Redis使用详解
2019/07/23 Python
Python爬取知乎图片代码实现解析
2019/09/17 Python
让IE支持HTML5的方法
2012/12/11 HTML / CSS
找到您丢失的钥匙、钱包和手机:Tile
2017/05/19 全球购物
世界顶级足球门票网站:Live Football Tickets
2017/10/14 全球购物
施华洛世奇韩国官网:SWAROVSKI韩国
2018/06/05 全球购物
主题班会演讲稿
2014/05/22 职场文书
汉语言文学毕业求职信
2014/07/17 职场文书
酒店管理失职检讨书
2014/09/16 职场文书
村党的群众路线教育实践活动总结材料
2014/10/31 职场文书
党的群众路线教育实践活动学习笔记
2014/11/05 职场文书
晚会开幕词
2015/01/28 职场文书
北京故宫导游词
2015/01/31 职场文书
教师工作表现自我评价
2015/03/05 职场文书
2019入党申请书格式和范文
2019/06/25 职场文书