1、数据库设计往往需要和前端界面的设计并行,前者稍晚于后者
2、原则上讲百张表内的数据库最好由一个人设计,如果项目过大则选择出一位主设计师来协调
3、DBA应该是在被需要的时候出现,而不应该被强制需要。当出现开发人员无法解决的问题时,例如数据量大到一定程度、数据丢失、数据备份等
4、开发模式:前端、后端、数据库明确分工
5、数据编码:建议将MySQL的编码设置为utf8,表类型统一使用InnoDB,InnoDB提供事务支持及外部键等高级功能,数据库默认安装的就是InnoDB类型
6、高级功能:存储过程、触发器、函数、视图、事件。(不同的数据库存储过程、触发器、函数等的编写方式差异巨大,很难统一控制。视图更没有必要,可以用连接查询实现)
7、遵循数据库三范式
参考知乎链接:https://www.zhihu.com/question/24696366
8、连接查询的使用:一般的业务系统,允许三张表以内的链接查询,超过五张的要禁止。禁止使用子查询,子查询换成关联查询。
9、尽量避免多表连接查询。。。
敲不下去了,具体参考知乎链接:
https://www.zhihu.com/question/39967106