关于数据库表设计的一点体会
2017-08-08 11:04
281 查看
以一个实际工作为例,在一个金融系统中,从业务上看有投资人和借款人这两类用户,但从用户类别上看有企业用户和个人用户,请问建表时如何做比较好。
方式一:
user表
user_person表、user_enterprise表
方式二:
user表
user_investor 投资人表 、 user_borrower 借款人表
注意:上述两种方式中user表均为用户总表,user表下面的两张表是user表的子集,会分别引用user表的中的主键,是具体的用户表,即user表中为所有用户的公共字段,具体表中包含具体用户的信息
点评:方式一的方式不好,因为从业务上看,投资人暂为个人用户,借款人分企业用户和个人用户,一个人不可能即是个人用户又是企业用户,所以无法同时出现在二张表中,且不是根据业务进行分表,这样在涉及到借款业务时,需要接触两张表去完成业务,而方式二就不存在这种情况。因为系统毕竟是业务系统,方式二的建表很好的体现了业务。在方式二中,一个人可以出现在投资人表中,也可以同时出现在借款人表中,这样在涉及到业务时,只需要接触一张表。
如果是一个人员管理系统,那么建表的方式当另有更好的方式,所以根据不同的场景,同样的表会有不同的建模。
方式一:
user表
user_person表、user_enterprise表
方式二:
user表
user_investor 投资人表 、 user_borrower 借款人表
注意:上述两种方式中user表均为用户总表,user表下面的两张表是user表的子集,会分别引用user表的中的主键,是具体的用户表,即user表中为所有用户的公共字段,具体表中包含具体用户的信息
点评:方式一的方式不好,因为从业务上看,投资人暂为个人用户,借款人分企业用户和个人用户,一个人不可能即是个人用户又是企业用户,所以无法同时出现在二张表中,且不是根据业务进行分表,这样在涉及到借款业务时,需要接触两张表去完成业务,而方式二就不存在这种情况。因为系统毕竟是业务系统,方式二的建表很好的体现了业务。在方式二中,一个人可以出现在投资人表中,也可以同时出现在借款人表中,这样在涉及到业务时,只需要接触一张表。
如果是一个人员管理系统,那么建表的方式当另有更好的方式,所以根据不同的场景,同样的表会有不同的建模。
相关文章推荐
- [企业信息化]关于数据库表设计的一点体会
- 关于设计数据库的一点心得
- 请教新设计的数据库组建, 关于跨数据库的一点心得, 大家一起讨论一下(二)
- 数据库设计---关于建表的时候选择横表和竖表(纵表)的一点思考
- 数据库设计---关于建表的时候选择横表和竖表(纵表)的一点思考
- 数据库设计---关于建表的时候选择横表和竖表(纵表)的一点思考
- 关于数据库设计的一点心得
- 请教新设计的数据库组建, 关于跨数据库的一点心得, 大家一起讨论一下
- 关于点击排行榜的数据库设计的一点心得
- 关于VC数据库开发中数据库连接与效率的问题-----一点体会和经验
- 数据库设计---关于建表的时候选择横表和竖表(纵表)的一点思考
- 数据库设计---关于建表的时候选择横表和竖表(纵表)的一点思考
- 最近关于编程学习的一点小体会
- 数据库设计的一点经验
- 关于项目管理的一点体会
- 关于数据库设计中的分级分层问题的总结(适用于组织结构图及家谱等问题)转
- 关于Entity Framework 4.0/4.1数据验证的一点体会
- 关于使用SQL Server LocalDB 一点体会
- 大家好,分享一点关于数据库的一些基本的例题
- 2017年1月-关于数据库表设计、查询、统计的想法。