【MySql】赶集网mysql开发36条军规

【MySql】赶集网mysql开发36条军规 2012-05-14 14:02:33

分类: Linux

写在前面的话:

总是在灾难发生后,才想起容灾的重要性;

总是在吃过亏后,才记得曾经有人提醒过。

(一)核心军规

(1)不在数据库做运算

cpu计算务必移至业务层;

(2)控制单表数据量

int型不超过1000w,含char则不超过500w;

合理分表;

限制单库表数量在300以内;

(3)控制列数量

字段少而精,字段数建议在20以内;

(4)平衡范式与冗余

效率优先;

往往牺牲范式;

(5)拒绝3B

拒绝大sql语句:big sql

拒绝大事物:big transaction

拒绝大批量:big batch

(二)字段类军规

(6)用好数值类型

tinyint(1Byte)

smallint(2Byte)

mediumint(3Byte)

int(4Byte)

bigint(8Byte)

bad case:int(1)/int(11)

(7)字符转化为数字

用int而不是char(15)存储ip

(8)优先使用enum或set

例如:`sex` enum (‘F’, ‘M’)

(9)避免使用NULL字段

NULL字段很难查询优化;

NULL字段的索引需要额外空间;

NULL字段的复合索引无效;

bad case:

`name` char(32) default null

`age` int not null

good case:

`age` int not null default 0

(10)少用text/blob

varchar的性能会比text高很多;

实在避免不了blob,请拆表;

(11)不在数据库里存图片

这个我不能理解!

但这是赶集网的经验,求detail!

(三)索引类军规

(12)谨慎合理使用索引

改善查询、减慢更新;

索引一定不是越多越好(能不加就不加,要加的一定得加);

覆盖记录条数过多不适合建索引,例如“性别”;

(13)字符字段必须建前缀索引

(14)不在索引做列运算

!!!不只是索引,都不能做列运算吧!!!

bad case:

select id where age +1 = 10;

(15)innodb主键推荐使用自增列;

主键建立聚簇索引;

主键不应该被修改;

字符串不应该做主键;

如果不指定主键,innodb会使用唯一且非空值索引代替;

(16)不用外键

请由程序保证约束;

(四)sql类军规

(17)sql语句尽可能简单

一条sql只能在一个cpu运算;

大语句拆小语句,减少锁时间;

一条大sql可以堵死整个库;

(18)简单的事务

事务时间尽可能短;

bad case:

上传图片事务

(19)避免使用trig/func

触发器、函数不用;

客户端程序取而代之;

(20)不用select *

消耗cpu,io,内存,带宽;

这种程序不具有扩展性;

(21)OR改写为IN()

or的效率是n级别;

in的消息时log(n)级别;

in的个数建议控制在200以内;

select id from t where phone=’159′ or phone=’136′;

=>

select id from t where phone in (’159′, ’136′);

(22)OR改写为UNION

mysql的索引合并很弱智

select id from t where phone = ’159′ or name = ‘john’;

=>

select id from t where phone=’159′

union

select id from t where name=’jonh’

(23)避免负向%

(24)慎用count(*)

(25)同上

(26)limit高效分页

limit越大,效率越低

select id from t limit 10000, 10;

=>

select id from t where id > 10000 limit 10;

(27)使用union all替代union

union有去重开销

(28)少用连接join

(29)使用group by

分组;

自动排序;

(30)请使用同类型比较

(31)使用load data导数据

load data比insert快约20倍;

(32)打散批量更新

(33)新能分析工具

show profile;

mysqlsla;

mysqldumpslow;

explain;

show slow log;

show processlist;

show query_response_time(percona);

时间: 2024-10-13 19:57:24

【MySql】赶集网mysql开发36条军规的相关文章

赶集网mysql开发36条军规

写在前面的话: 总是在灾难发生后,才想起容灾的重要性: 总是在吃过亏后,才记得曾经有人提醒过. (一)核心军规 (1)不在数据库做运算 cpu计算务必移至业务层: (2)控制单表数据量 int型不超过1000w,含char则不超过500w: 合理分表: 限制单库表数量在300以内: (3)控制列数量 字段少而精,字段数建议在20以内: (4)平衡范式与冗余 效率优先: 往往牺牲范式: (5)拒绝3B 拒绝大sql语句:big sql 拒绝大事物:big transaction 拒绝大批量:big

MySQL开发36条军规

转载地址:http://blog.itpub.net/22664653/viewspace-723506/ 写在前面的话: 总是在灾难发生后,才想起容灾的重要性: 总是在吃过亏后,才记得曾经有人提醒过. (一)核心军规 (1)不在数据库做运算 cpu计算务必移至业务层: (2)控制单表数据量 int型不超过1000w,含char则不超过500w: 合理分表: 限制单库表数量在300以内: (3)控制列数量 字段少而精,字段数建议在20以内: (4)平衡范式与冗余 效率优先: 往往牺牲范式: (5

星瀚资本杨歌:我七次创业失败的内心感悟(比较真实,可以看看创业的36条军规)

猎云网注:杨歌,星瀚资本创始合伙人.作为一名连续创业者,参与创办了东信康达红外数字医疗及凯业网等,曾担任北国投投资总监.大江投资副总裁.毕马威咨询师.投资的案例包括口碑街.言几又.人人财务.V.Fine等.拥有清华大学工学硕士与学士学位.他分享了创业失败的感悟.本文来自投资人说(ID:touzirenshuo),转载请注明来源. 1.年轻人要大胆地去犯错 谢谢大家今天能来到投资人说听我分享,我是星瀚资本的创始合伙人杨歌. 提到硅谷大家都感觉很高大上,的确,硅谷的外表看上去很光鲜,但其实在硅谷的大

创业的36条军规

[创业军规1]创业者,人生之大事也,不可轻启.创业是带着一群未知的人去一个未知的地方干一件未知的事儿,九死一生,如果没有做好破釜沉舟的决心,最好不要启程. [创业军规2]只有20%的人适合创业,适合创业的人之中只有5%的人适合当总经理.敢于创业并且敢于让比自己更适合的人当总经理的创业者成功机会更大.作为创业团队的成员,周恩来与毛泽东作用同样伟大. [创业军规3]创业的机会成本非常大.大凡想创业的的人,都是同辈中的佼佼者,把创业的热情和心思用在好好打工上,很可能会飞速升官发财,选择创业,进入的是一

用尽洪荒之力整理的Mysql数据库32条军规

今天上午吐血整理了Oracle SQL性能优化的40条军规,其中很多规则也是适用于Mysql的,结果今晚发现这一篇文章——用尽洪荒之力整理的Mysql数据库32条军规,和我的竟有异曲同工之妙,当然不同的是这是由具有12年Java开发经验的老鸟写的,其见解和认识肯定比我的更加深刻,感谢前辈,现全文转载如下: --------------------------------------------------------------split line------------------------

使用ThinkPHP开发中MySQL性能优化的最佳21条经验

使用ThinkPHP开发中MySQL性能优化的最佳21条经验讲解,目前,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我 们程序员需要去关注的事情.当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能.这里,我们不会讲过 多的SQL语句的优化,而只是针对MySQL这一Web应用最多的数据库.希望下面的这些优化技巧对你有用. 1. 为查询缓存优化你的查询大多数的MySQ

基于struts 2.3的家政服务平台V2.0粉色主题-java家政服务平台家政网mysql

基于struts 2.3的家政服务平台V2.0粉色主题-java家政服务平台家政网mysql数据源 1.包含源程序,数据库脚本.2.课题设计仅供参考学习使用,可以在此基础上进行扩展完善.开发环境:Eclipse ,MySQL 5.1,JDK1.7,Tomcat 7涉及技术点:MVC模式.JavaWeb.Struct.JDBC.HTML.CSS.JQUERY.Maven.C3P0.分页.文件上传.购物车等.实现功能:充值.购买歌曲.poi数据导入导出.歌曲上传下载.歌曲播放.用户注册登录注销,管理

linux 下安装 mysql 并配置 python 开发环境

1.安装 mysql ,安装过程中将提示设置 root 用户的密码,默认可以设置为 rootadmin . $ sudo apt-get install mysql-server 2.安装 mysql 开发工具(不安装时,安装 MySQL-python 提示错误 "mysql_config not found"). $ sudo apt-get install libmysqld-dev 3.安装 python 的 mysql 库 MySQL-python (首先安装 python-d

MySQL性能优化的最佳20+条经验

http://www.pythonclub.org/mysql/optimize-20-tips 今天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于数据库的性能,这并不只是DBA才需要担心的事,而这更是我们程序员需要去关注的事情.当我们去设计数据库表结构,对操作数据库时(尤其是查表时的SQL语句),我们都需要注意数据操作的性能.这里,我们不会讲过多的SQL语句的优化,而只是针对MySQL这一Web应用最多的数据库.希望下面的这些优化技巧对你有用. 1. 为查询缓存