MySql字段类型的选择

1.主键设计

主键不要与业务逻辑有所关联,最好是毫无意义的一串独立不重复的数字,且自增,最好设计为Long类型,对应MySQL的bigint

bigint详解: MySQL_bigint(20) 是什么意思? - 根号829 - 博客园

2.关于外键

  尽量不要建立外键,保证每个表的独立性。如果非得保持一定的关系,最好是通过id进行关联,我们使用业务进行管理,否则每次删除或更新都会关联查询,性能差,可以把这个逻辑放在业务层里,避免额外的查询

3.动静分离

       最好做好静态表和动态表的分离。这里解释一下静态表和动态表的含义,静态表:存储着一些固定不变的资源,比如城市/地区名/国家(静态表一定要使用缓存)。动态表:一些频繁修改的表

     这样做的好处是当我根据主键查询所需的数据时,根据id到磁盘查找出这条数据即可,当作了动静分离后,这次取出的数据就是经常修改的那部分数据,而不经常修改的数据在另一个表中,物理上不相邻,这次用不到就不会被取出

4.资源存储

数据库不要存储任何资源文件,比如照片/视频/网站等,可以用文件路径/外链用

5.字段长度

    建表的时候,字段长度尽量要比实际业务的字段大3-5个字段左右(考虑到合理性和伸缩性),

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值