我们该如何设计数据库(二)

最近公司要开发新系统,基本决定使用ORM(高层还在犹豫,担心效率问题)。既然使用了ORM,那么自然而然的就想到了用面向对象的思想来设计数据库。

本篇文章旨在讨论如何抽象(以用户作为抽象的例子),并提出一些解耦的思路。

我也是***次在实际项目中使用面向对象的思想来设计数据库,写下这篇博客,也是希望与大家多多交流。

正文开始

首先来需求分析

我们的系统有前台和后台,前台用户有:Man,Woman,SuperMan,SpiderMan与IronMan。后台用户为Administrator。

前台用户都要填写联系方式与地址,然后SuperMan,SpiderMan与IronMan都有Ability。

需求很简单。那么按照这个需求,我们来随手画一个继承关系图。其中V代表抽象类(应该是abstract,画图的时候脑抽想着是virtual就用V开头了,懒得改图了大家凑合着看吧),I代表Interface。如下图:

从图中可以看出,由抽象类Person派生出Administration与抽象类User。类Man与类Womam实现了接口Address与接口Contact,Inhumans则实现了Ability接口。

然后抽象类代码:

  1. View Code   
  2.  
  3.     public abstract class Person  
  4.     {  
  5.         public string Username { get; set; }  
  6.         public string Password { get; set; }  
  7.     }  
  8.  
  9.     public abstract class User : Person  
  10.     {  
  11.         public string Name { get; set; }  
  12.     } 

接口代码:

  1. View Code   
  2.  
  3.     public interface IAddress  
  4.     {  
  5.         string Address { get; set; }  
  6.     }  
  7.  
  8.     public interface IContact  
  9.     {  
  10.          string Email{get;set;}  
  11.          string WorkPhone { get; set; }  
  12.          string MobilePhone { get; set; }  
  13.          string Fax { get; set; }  
  14.     } 

***是Man类和Woman类:

  1. View Code   
  2.  
  3.     public class Man : User, IContact, IAddress  
  4.     {  
  5.         public string Address { get; set; }  
  6.         public string Email { get; set; }  
  7.         public string WorkPhone { get; set; }  
  8.         public string MobilePhone { get; set; }  
  9.         public string Fax { get; set; }  
  10.  
  11.         public bool HasCar { get; set; }       //如果这三项都为false的话  
  12.         public bool HasHouse { get; set; }     //这辈子就甭想结婚了  
  13.         public bool HasMoney { get; set; }     //T T我泪涌  
  14.     } 
  1. View Code   
  2.  
  3.     class Woman : User, IAddress, IContact  
  4.     {  
  5.         public string Address { get; set; }  
  6.         public string Email { get; set; }  
  7.         public string WorkPhone { get; set; }  
  8.         public string MobilePhone { get; set; }  
  9.         public string Fax { get; set; }  
  10.  
  11.         public bool IsBeauty { get; set; }  //这个为true,一辈子不愁吃喝  
  12.     } 

代码非常简单。其他几个类限于篇幅就不说那么细了。

那么按照这个model,使用EF Model First来建立数据库,得到的Woman表如下:

那么接下来就是重点了:为什么不把Contact和Address分表储存。这样与Man表、Woman表写在一起的话,出现改动(如新增一种联系方式),会不会非常痛苦。

如果不是使用ORM,那么这个改动的确是很痛苦;但是如果使用了(这里默认使用的ORM可以从Model生成/改动数据库),那么这个改动是没什么大不了的了,只需要修改一下接口定义,然后根据报错去改就好了。至于数据库的变动,就交给ORM去做就OK了。

这样有一个好处,可以在有限的范围内实现解耦,部分减少了关系——若将Contact和Address分表的话,取Woman要Join两次,这看起来没什么大不了的,但是如果放大了看,如果是join十次呢?这样弄出来的东西很难去维护(现在公司老系统就是这样,动不动就join十次二十次的,改动起来十分费力)

具体怎么去解耦,这个问题相当相当的深奥,就不敢在这班门弄斧了。

原文链接:http://www.cnblogs.com/CrazyJinn/archive/2012/08/20/2637459.html

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/228544.html<

(0)
运维的头像运维
上一篇2025-04-18 08:42
下一篇 2025-04-18 08:44

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注