mysql浅龟定
一,尽量不字啊数据库做运算
1,尽量不再数据库做运算,
2,将复杂运算移动到cpu
3,尽可能简单应用mysql
二,控制表数据量
1,纯 int不超过1000w
2,含char不超过500w
3,建议单裤不超过300-400个表
三,保持表的苗条身材
1,表的字段数少而精
2,单表字段数上限在20~50个
四,平衡范式和冗余
1,效率优先,提升性能
2,没有绝对的对与错
3,适当牺牲范式,加入冗余
五,拒绝3B
1,大SQL
2,大事务
3,大批量
六,字段设置龟定
1,将字符转化为数字(更高效,查询快,占空间更小)
2,优先使用enum或set(值已知或有限,如 性别)
3,避免使用NULL字段(很难优化查询,加索引需要额外空间,含NULL复合索引无效)
4,尽量不使用text/blob(必须使用时拆分到单独的表)
5,不再数据库存图片
七,索引浅龟定
1,谨慎添加索引
2,最好不超过字段数20%
3,字段前加前缀
4,不在索引列做运算
八,主键设置
1,二级索引存储主键值2,主键不应更新或者修改3,按自增顺序插入值4,忌用字符串做主键5,若不指定主键,innoDB会使用唯一且非空值索引代替
九,事务,触发器,or,limit浅龟定1,事务/连接使用原则:即开即用,用完即关
2,与事务无关的操作放到事务外面,减少锁资源的占用
3,不破坏一致性的前提下,使用多个短事务代替长事务4,尽可能少用存储过程
5,尽可能少使用触发器6,减少使用mysql函数对结果进行处理(由客户端程序负责)
7,尽量不适用select *,只取需要的数据列
8,改or为in()【or效率 O(n),in效率O(log n)】控制in的数量,建议小于2009,改or为union
10,减少使用count(*)
11,limit(偏移量越大则越慢)
select id,col1,col2 from test limit 1999999,10;
替换为:
select id,col1,col2 from test where id>1999999 limit 10;
杂项浅龟定:
1,适当分解连接保证高效并发
2,永远不再程序端显式加锁【外部锁对数据库不可控,高并发是时灾难】
3,统一字符集为utf-8
4,统一命名规范【库表名统一小写,索引名称默认为"idx_字段名",库名用缩写】
mysql浅龟定的更多相关文章
- Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理
基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...
- MySQL浅谈 LEFT JOIN
On条件(在“A left join b on conditional_expr”)决定如何从table B 中检索数据行(Matching-State); 如果B中没有行匹配On 条件,额外的B的所 ...
- sql server 与 mysql在自定以数据类型的区别
sql server 中可以使用 create TYPE postal_code FORM varchar(6) not null; 用于限定邮编的数据位数,他基于varchar数据类型 注意: ...
- mysql浅谈--事务ACID特性
mysql MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管 ...
- mysql简单建表
MySQL 字段约束 null,not null,default,auto_increment [来源于] 没有规矩,不成方圆,任何事物都是如此.在MySQL中,每个字段定义都包含附加约束或者修饰符, ...
- 关于MySQL的安装使用心得
MySQL浅浅地学习了几天,当然还是转到正轨Java上来了,昨天打了一串代码,测试注解来着,结果MySQL挂了~~~ 如何干净卸载MySQL帖子有很多,不再赘述,注册表是个好东西~~ 卸载了Mysql ...
- MYSQL索引结构原理、性能分析与优化
[转]MYSQL索引结构原理.性能分析与优化 第一部分:基础知识 索引 官方介绍索引是帮助MySQL高效获取数据的数据结构.笔者理解索引相当于一本书的目录,通过目录就知道要的资料在哪里, 不用一页一页 ...
- MySql UDF 调用外部程序和系统命令
1.mysql利用mysqludf的一个mysql插件可以实现调用外部程序和系统命令 下载lib_mysqludf_sys程序:https://github.com/mysqludf/lib_mysq ...
- centos7下 安装mysql
wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-community-rele ...
随机推荐
- 初识Java(2) 变量与数据类型
一. 变量 1.变量是内存中的一个标识符号,用于存储数据 2.变量命名规则 1) 必须以字母.下划线 _ .美元符号 $ 开头 2) 变量中,可以包括数字 3) 变量中,不能出现特殊的符号,空格 4 ...
- dede系统自定义变量删除方法
之前添加了个联系电话的系统变量,忘记写描述,结果就显示个冒号,很难看.这样的就要删除了重来,那么织梦怎么删除添加的变量呢?其实很简单.两种方法: 第一种:执行SQL语句.在织梦后台执行-系统-SQL命 ...
- python装饰器大详解
1.作用域 在python中,作用域分为两种:全局作用域和局部作用域. 全局作用域是定义在文件级别的变量,函数名.而局部作用域,则是定义函数内部. 关于作用域,我要理解两点:a.在全局不能访问到局部定 ...
- Java基础——多态
多态性是指允许不同类型的对象对同一消息做出相应.具有灵活性.抽象.行为共享.代码共享的优势,共享就意味着最大化利用和简洁,还有就是加载速度. 一.多态的作用 消除类型之间的耦合关系.即同一事件发生在不 ...
- css清除浮动的集中方法
一:浮动产生的副作用 1.父元素的背景不能显示 2.父元素的边框不能撑开 3.padding和margin失效 二:清除浮动的方法 1.给父元素设置高度:这样可以清除浮动,但是子元素内容高度不固定,这 ...
- EL表达式拼接字符串
EL表达式拼接字符串<c:set var="types" value="${','}${resMap['vo'].lineType }${','}" &g ...
- jrebel配置热部署参数
jrebel配置热部署参数: -noverify -agentpath:D:/jrebel/lib/jrebel64.dll -Drebel.dirs=E:/workspace/item/src/ma ...
- django-xadmin中APScheduler的启动初始化
环境: python3.5.x + django1.9.x + xadmin-for-python3 APScheduler做为一个轻量级和使用量很多的后台任务计划(scheduler)包,可以方便 ...
- C语言之复杂链表的复制(图示详解)
什么是复杂链表? 复杂链表指的是一个链表有若干个结点,每个结点有一个数据域用于存放数据,还有两个指针域,其中一个指向下一个节点,还有一个随机指向当前复杂链表中的任意一个节点或者是一个空结点.今天我们要 ...
- ExtJs的Ext.Ajax.request实现waitMsg等待提示效果
一. fp.form.submit 有waitMsg 属性来设置等待效果,如下.但是对于Ext.Ajax.request来说 waitMsg 并不起作用. f ...