一,尽量不字啊数据库做运算

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浅龟定的更多相关文章

  1. Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理

    基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...

  2. MySQL浅谈 LEFT JOIN

    On条件(在“A left join b on conditional_expr”)决定如何从table B 中检索数据行(Matching-State); 如果B中没有行匹配On 条件,额外的B的所 ...

  3. sql server 与 mysql在自定以数据类型的区别

    sql server   中可以使用 create  TYPE postal_code FORM varchar(6) not null; 用于限定邮编的数据位数,他基于varchar数据类型 注意: ...

  4. mysql浅谈--事务ACID特性

    mysql MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管 ...

  5. mysql简单建表

    MySQL 字段约束 null,not null,default,auto_increment [来源于] 没有规矩,不成方圆,任何事物都是如此.在MySQL中,每个字段定义都包含附加约束或者修饰符, ...

  6. 关于MySQL的安装使用心得

    MySQL浅浅地学习了几天,当然还是转到正轨Java上来了,昨天打了一串代码,测试注解来着,结果MySQL挂了~~~ 如何干净卸载MySQL帖子有很多,不再赘述,注册表是个好东西~~ 卸载了Mysql ...

  7. MYSQL索引结构原理、性能分析与优化

    [转]MYSQL索引结构原理.性能分析与优化 第一部分:基础知识 索引 官方介绍索引是帮助MySQL高效获取数据的数据结构.笔者理解索引相当于一本书的目录,通过目录就知道要的资料在哪里, 不用一页一页 ...

  8. MySql UDF 调用外部程序和系统命令

    1.mysql利用mysqludf的一个mysql插件可以实现调用外部程序和系统命令 下载lib_mysqludf_sys程序:https://github.com/mysqludf/lib_mysq ...

  9. centos7下 安装mysql

    wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm rpm -ivh mysql-community-rele ...

随机推荐

  1. dedecms搜索提示"关键字不能小于2个字节!"

    在测试自己制作的搜索页模板时,如果遇到搜索时提示"关键字不能小于2个字节!"!打开plus/search.php把   if(($keyword=='' || strlen($keyword)< ...

  2. redis bitcount variable-precision swar算法

    花了不到一周的时间看完了一本reids设计与实现的书,感觉整体的设计有些地方的确很巧妙,各个结构之间联系的非常紧密,但是很简单,逻辑性的没有太多,但是学到了一个bitcount计数1的方法比较巧妙,记 ...

  3. php 数据访问基础

    <?php // 创建数据库连接 $con = mysql_connect("localhost",'root','') or die('error:'.mysql_erro ...

  4. 活动页怎么切图photoshop

    一 切固定大小的单个图片 1.用pc打开图像 2.按ctrl+A(全选) 3.点击 选择 ->变换选区 ->拉参考线(把参考线放到最中央)->按回车 ->ctrl+d(取消全选 ...

  5. DDD理论学习系列(7)-- 值对象

    DDD理论学习系列--案例及目录 1.引言 提到值对象,我们可能立马就想到值类型和引用类型.而在C#中,值类型的代表是strut和enum,引用类型的代表是class.interface.delega ...

  6. Nignx入门location、root配置

    nginx的配置.首当其冲的就是location配置了,下面是笔记参考的博文链接 http://www.cnblogs.com/sunkeydev/p/5225051.html   location匹 ...

  7. PHP扩展开发-1

    开发环境信息 1.基本环境信息如下: [root@localhost lib]# cat /etc/os-release NAME="CentOS Linux" VERSION=& ...

  8. 用Html5/CSS3做Winform,一步一步教你搭建CefSharp开发环境(附JavaScript异步调用C#例子,及全部源代码)上

    本文为鸡毛巾原创,原文地址:http://www.cnblogs.com/jimaojin/p/7077131.html,转载请注明 CefSharp说白了就是Chromium浏览器的嵌入式核心,我们 ...

  9. 关闭数据库下的所有连接操作 sql存储过程

    use master go )) as begin ),) declare @spid int set @sql='declare getspid cursor for select spid fro ...

  10. 既然函数也是对象,那么为什么this不指向普通函数?

    function a(){ var b=1; function exp(){ alert(this.b); } exp(); } var b=2; a(); 既然函数是对象,且exp是在a中运行的,那 ...