设计一用户系统的问题:用户分若干种类型,所有类型的用户都有一些共同的字段属性。但是,不同类型的用户,也有各自不同的字段属性。都是些互不相干的字段。请问大家经常是怎么设计这个数据系统的,用一个表就够了,还是用两个表?

解决方案 »

  1.   

    用多个表的话,主表是好做的譬如:A类用户字段 = 主表字段 + A类自己的字段     B类用户字段 = 主表字段 + B类自己的字段     C类用户字段 = 主表字段 + C类自己的字段那A类\B类\C类各自的字段,又怎么存储呢?用三个表?或者用一个表,怎么设计?
      

  2.   

    就用多个表吧
    A(a1,a2,a3...an,p='a')
    B(b1,b2,b3...bn,p='b')
    C(c1,c2,c3...cn,p='c')
    P(p1,p2,p3...pn,abc{'a' | 'b' | 'c'})不知道标准语法怎么写,希望楼主能明白我的意思.
      

  3.   

    主表:用户编号、用户类型、用户名及其他共有字段,也可以有个类型用户的副表的表名
    A表:用户编号,A类用户的特殊字段
    B表:用户编号,B类用户的特殊字段
      

  4.   

    see  《wrox高级web编程》
      

  5.   

    如果你的类型数量可能是未知的,比如M个,不同类型的用户的属性数量也是未知的,比如N个,那么不管是一个表还是多个表,都会遇到类似的问题:多个表方式:动态地建M个表?一个表的方式,动态的添加字段,到N个属性字段。在这种情况下,我想用多个表的方式更容易处理。
      

  6.   

    如何动态创建表,字段?
    用SqlCommand(或其他) 执行SQL的Create table 语句
    还有,如果用一个表的话,那当我插入一条属于B类的记录的时候,在属于A类所专有的字段上,该填什么呢?空着吗?
    空着
      

  7.   

    1. 原始单据与实体之间的关系
      可以是一对一、一对多、多对多的关系。在一般情况下,它们是一对一的关系:即一张原始单据对应且只对应一个实体。在特殊情况下,它们可能是一对多或多对一的关系,即一张原始单证对应多个实体,或多张原始单证对应一个实体。这里的实体可以理解为基本表。明确这种对应关系后,对我们设计录入界面大有好处。
    〖例1〗:一份员工履历资料,在人力资源信息系统中,就对应三个基本表:员工基本情况表、社会关系表、工作简历表。这就是“一张原始单证对应多个实体”的典型例子。
       2. 主键与外键
      一般而言,一个实体不能既无主键又无外键。在E—R 图中, 处于叶子部位的实体, 可以定义主键,也可以不定义主键(因为它无子孙), 但必须要有外键(因为它有父亲)。
      主键与外键的设计,在全局数据库的设计中,占有重要地位。当全局数据库的设计完成以后,有个美国数据库设计专家说:“键,到处都是键,除了键之外,什么也没有”,这就是他的数据库设计经验之谈,也反映了他对信息系统核心(数据模型)的高度抽象思想。因为:主键是实体的高度抽象,主键与外键的配对,表示实体之间的连接。
       3. 基本表的性质
      基本表与中间表、临时表不同,因为它具有如下四个特性:
       (1) 原子性。基本表中的字段是不可再分解的。
       (2) 原始性。基本表中的记录是原始数据(基础数据)的记录。
       (3) 演绎性。由基本表与代码表中的数据,可以派生出所有的输出数据。
       (4) 稳定性。基本表的结构是相对稳定的,表中的记录是要长期保存的。
    理解基本表的性质后,在设计数据库时,就能将基本表与中间表、临时表区分开来。   4. 范式标准
      基本表及其字段之间的关系, 应尽量满足第三范式。但是,满足第三范式的数据库设计,往往不是最好的设计。为了提高数据库的运行效率,常常需要降低范式标准:适当增加冗余,达到以空间换时间的目的。
    〖例2〗:有一张存放商品的基本表,如表1所示。“金额”这个字段的存在,表明该表的设计不满足第三范式,因为“金额”可以由“单价”乘以“数量”得到,说明“金额”是冗余字段。但是,增加“金额”这个冗余字段,可以提高查询统计的速度,这就是以空间换时间的作法。
      在Rose 2002中,规定列有两种类型:数据列和计算列。“金额”这样的列被称为“计算列”,而“单价”和“数量”这样的列被称为“数据列”。
      表1 商品表的表结构
      商品名称 商品型号 单价 数量 金额
      电视机 29吋 2,500 40 100,000
       5. 通俗地理解三个范式
      通俗地理解三个范式,对于数据库设计大有好处。在数据库设计中,为了更好地应用三个范式,就必须通俗地理解三个范式(通俗地理解是够用的理解,并不是最科学最准确的理解):
      第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;
      第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
      第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余.