ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

数据库设计技巧

2021-12-22 11:00:47  阅读:131  来源: 互联网

标签:insert 自增 技巧 autoinc 数据库 mode 设计 主键 UUID


数据库设计技巧
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 ......

标签:insert,自增,技巧,autoinc,数据库,mode,设计,主键,UUID
来源: https://www.cnblogs.com/changbaishan/p/15718518.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有