zoukankan      html  css  js  c++  java
  • 数据库设计技巧

    数据库设计技巧
    1. 每张表都要设计主键
       不建议用自增整数作为主键。
       原因: 1) 自增存在回溯问题; 2) 自增值在服务器端产生,存在并发性能问题。
        3) 无法保证全局唯一,只能当前唯一。4)自增值存在安全问题 5)分布式架构问题。6)MySQL Group Replication 下存在性能问题。
        7) 自增存在跳跃变化,高并发下。
    2. 自增主键下性能差原因
       innodbicon_autoinc_lock_mode 控制自增主键获取锁的行为;
       insert 分为三类:
       1) simple insert 比如insert into test(name)values("miao")
       2) bulk   insert 比如load data 或insert into ... select * from ..
       3) mixed insert  比如insert into t(id,name) values(1,'a'),(2,'b'),(3,'c');
     
       innodb_autoinc_lock_mode为0:
       1 在语句开始加表级别的auto_inc 锁 性能差。
       2 保证值得连续性,可重复性(复制)。
     
       innodb_autoinc_lock_mode为1:
        1. 默认模式,simple insert 下一次性插入数可以立刻确认,auto_inc 锁不一定要到语句执行结束,对于3这种语句会加锁和释放一次。
        2. binlog格式 binlog_format 下复制安全,statement 不安全。

       innodb_autoinc_lock_mode为2:   1. 性能最好,像3这类sql,自增锁持有多次。   2. 自增值可能不连续。
    3. 推荐主键类型  1) uuid 转bin  mysql 8.0后用  UUID_TO_BIN/BIN_TO_UUID 函数    如:SELECT UUID_TO_BIN('103a34d4-641173-11eb-943c-00155db229d',TRUE) as UUID_BIN;  2) 业务定义主键:PK = 时间信息  + 业务信息1 + 业务信息2 ......

  • 相关阅读:
    Mongo Windows 基本使用入门
    ASP.NET Web API 使用Swagger使用笔记
    Smtp协议与Pop3协议的简单实现
    详解boost库中的Message Queue .
    Bencode编码解析的C++实现
    pugixml使用教程
    在QT中使用Irrlicht引擎的方法与步骤
    七大查找算法
    java保留小数点两位的4种方法
    [Node] nvm 安装 node 和 npm
  • 原文地址:https://www.cnblogs.com/changbaishan/p/15718518.html
Copyright © 2011-2022 走看看