zoukankan      html  css  js  c++  java
  • Entity Framework 复杂类型

     

    为了说明什么是复杂属性,先举一个例子。

    复制代码
     public class CompanyAddress
        {
            public int ID { get; set; }
            public string CompanyName { get; set; }
            public string StreetAddress { get; set; }
            public string City { get; set; }
            public string State { get; set; }
            public string ZipCode { get; set; }
        }
    
        public class FamilyAddress
        {
            public int ID { get; set; }
            public string StreetAddress { get; set; }
            public string City { get; set; }
            public string State { get; set; }
            public string ZipCode { get; set; }
        }
    复制代码

    上面有两个类:公司地址和家庭地址,它们有四个相同的属性:StreetAddress、City、State、ZipCode。映射到数据库中的结构如图:

    这里,我们可以将这四个属性集合成一个复杂属性Address,修改后的类为:

    复制代码
    public class CompanyAddress
        {
            public int ID { get; set; }
            public string CompanyName { get; set; }
            public Address Address { get; set; }
        }
    
        public class FamilyAddress
        {
            public int ID { get; set; }
            public Address Address { get; set; }
        }
    
        [ComplexType]
        public class Address
        {
            public string StreetAddress { get; set; }
            public string City { get; set; }
            public string State { get; set; }
            public string ZipCode { get; set; }
        }
    复制代码

    此时,所生成的数据库如图:

    可以看到,两张表中仍然具有相应的地址属性信息。代码中的Address类就是复杂属性,它并不会在数据库中映射成相应的表,但我们的代码确简洁了许多。

    所以如果有几个属性在几个类中都有用到,那么就可以将这几个属性集合成一个复杂类型,并在相应的类中增加这个复杂类型的属性。

  • 相关阅读:
    Sql 字符串按指定字符转多行(表值函数)
    C# 默认打印机设置
    Sql server 触发器状态查询
    指定周转对应日期
    Java发送HttpRequest
    Java实现手机号码归属地判别
    MySQL导入.sql文件及常用命令
    解释和编译的区别
    Java中的static关键字解析
    内存堆和栈的区别
  • 原文地址:https://www.cnblogs.com/liangxiaofeng/p/5809957.html
Copyright © 2011-2022 走看看