zoukankan      html  css  js  c++  java
  • 设计库和表从哪些方面考虑(MYSQL)

    • 选择合适字段类型:

    字段尽量选择的越小越好,因为越短的类型占用的磁盘空间越小

    还有就是我们尽量选择使用固定长度或固定值得字段类型

    表的列字段最好不要太多,合适就好

    尽可能使用not null定义字段

    尽量少使用text字段类型,如果使用的话最好进行分表

    •   添加索引

    字段查询比较多的情况下建立索引

    字段要求不重复的情况下建立唯一索引

    主键尽量使用比较短的字段类型,减少磁盘占用空间

    避免创建过多的索引,降低写得速度

    非常小的表,全表扫描更快,没必要创建索引

    索引创建完后,还是要注意避免索引失效的情况

    • Sql优化

    不要把sql语句写的太长

    尽量避免使用子查询,使用连表代替子查询,尽量使用内关联查询,也就是等值关联

    尽量避免索引失效的情况

    尽量避免使用 select * ,只查找要使用的字段

    查询一条记录的时候尽量使用limit 1 避免表的扫描

    避免循环查询,减少应用程序与数据库的交互次数

     

    • 使用缓存

    减少应用程序和数据库交互的次数

    分区分表优化,range分区, 水平分表

    配置数据库的读写分离

    • 建立索引的原则

    在经常需要搜索的列上,可以加快搜索的速度

    在经常用在连接的列上,这些列主要是一外键,可以加快连接的速度

    在经常需要排序的列上,因为索引已经排序,这样可以利用索引的排序,加快排序时间

    在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构

  • 相关阅读:
    算法学习笔记: 珂朵莉树
    算法学习笔记:2SAT
    0x62 图论最小生成树
    Codeforces Round #632 (Div. 2) C. Eugene and an array(尺取法/前缀和)
    BZOJ1912 异象石(LCA/DFS序/set)
    (六1)Firefox插件安装
    (六2)八种定位方式为了查找元素
    (六3)从查找元素到操作元素
    【OSI】网络协议模型
    读《Wireshark网络分析就这么简单》读书笔记
  • 原文地址:https://www.cnblogs.com/zhumengyang/p/13346610.html
Copyright © 2011-2022 走看看