数据库设计技巧
2021/12/22 19:21:41
本文主要是介绍数据库设计技巧,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据库设计技巧
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 ......
这篇关于数据库设计技巧的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24怎么修改Kafka的JVM参数?-icode9专业技术文章分享
- 2024-12-23线下车企门店如何实现线上线下融合?
- 2024-12-23鸿蒙Next ArkTS编程规范总结
- 2024-12-23物流团队冬至高效运转,哪款办公软件可助力风险评估?
- 2024-12-23优化库存,提升效率:医药企业如何借助看板软件实现仓库智能化
- 2024-12-23项目管理零负担!轻量化看板工具如何助力团队协作
- 2024-12-23电商活动复盘,为何是团队成长的核心环节?
- 2024-12-23鸿蒙Next ArkTS高性能编程实战
- 2024-12-23数据驱动:电商复盘从基础到进阶!
- 2024-12-23从数据到客户:跨境电商如何通过销售跟踪工具提升营销精准度?