设计库和表从哪些方面考虑(MYSQL)

本文探讨了MySQL数据库设计和优化的关键点,包括选择合适的字段类型以减少磁盘占用,限制列数量,尽量使用NOT NULL定义字段,谨慎使用TEXT类型并考虑分表,合理创建索引以提高查询效率,避免索引失效。此外,还提出了SQL优化策略,如避免过长SQL和子查询,使用LIMIT 1等,以及使用缓存、分区分表和读写分离来提升性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 选择合适字段类型:

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

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

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

尽可能使用not null定义字段

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

  •   添加索引

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

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

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

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

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

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

  • Sql优化

不要把sql语句写的太长

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

尽量避免索引失效的情况

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

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

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

 

  • 使用缓存

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

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

配置数据库的读写分离

  • 建立索引的原则

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值