上一篇的中介绍过了对于EF4.1框架中,实体的简单属性的处理

这一篇介绍一下Code First方法中,实体Complex属性的处理。Complex属性是将一个对象做为另一个对象的属性。映射到数据库中则子对象表现为多个属性字段。

反之,也就是说,数据库中多个相关字段映射成一个子对象,来进行统一的管理。

complex属性要注意不同于外键引用对象的。

下面用Code First的方式先做个complex属性。

  1. public class Book
    {
    public int BookId { get; set; }
    public string BookTitle { get; set; }
    public Publisher Publisher { get; set; }
  2.  
  3. }
    [ComplexType]
    public class Publisher
    {
    public string PublisherName { get; set; }
    public string PublisherAddress { get; set; }
    }
  4.  
  5. public class BookDbContext : DbContext
    {
    public BookDbContext() : base("BookDB") {
    Database.SetInitializer<BookDbContext>(
    new DropCreateDatabaseIfModelChanges<BookDbContext>()
    );
    }
    public IDbSet<Book> Books { get; set; }
    }

在上面的代码中,构造了一个Book实体,包含一个complex属性publiser,Pubisher被标明了是ComplexType

创建数据库,并添加一条测试记录

  1. using (BookDbContext db = new BookDbContext())
    {
  2.  
  3. Book newbook = new Book()
    {
    BookTitle = "EF4.1 step by step",
    Publisher = new Publisher()
    {
    PublisherName = "机械工业",
    PublisherAddress = "北京"
    }
    };
    db.Books.Add(newbook);
    db.SaveChanges();
  4.  
  5. }

创建后的数据库如图示:

可以清楚的看到,complex属性作数据库的多个字段存在,命名格式为ComplexType.Property

直接获取属性值

第一种方法

  1. var book = db.Books.Find(1);
    ///直接获取complex属性的某个具体属性值
    var pubName = db.Entry(book).Property(b => b.Publisher.PublisherName).CurrentValue;
    Console.WriteLine(pubName);

第二种方法:

  1. var pubName1 = db.Entry(book)
    .ComplexProperty(b => b.Publisher)
    .Property(p => p.PublisherName).CurrentValue;
    Console.WriteLine(pubName1);

第三种方法:

  1. var pubName2 = db.Entry(book).Property("Publisher.PublisherName").CurrentValue;
    Console.WriteLine(pubName2.ToString());

获取complex属性对象

  1. ///获取复杂属性对象
    var pub = db.Entry(book).ComplexProperty<Publisher>(b=>b.Publisher).CurrentValue;
    Console.WriteLine(pub.PublisherName);

如果要全部输出所有属性,这里也提供一个方法

  1. public static void WritePropertyValues(string parentPropertyName, DbPropertyValues propertyValues)
    {
    foreach (var propertyName in propertyValues.PropertyNames)
    {
    var nestedValues = propertyValues[propertyName] as DbPropertyValues;
    if (nestedValues != null)
    {
    WritePropertyValues(parentPropertyName + propertyName + ".", nestedValues);
    }
    else
    {
    Console.WriteLine("Property {0}{1} has value {2}",
    parentPropertyName, propertyName,
    propertyValues[propertyName]);
    }
    }
    }

调用这个方法的方式如下:

  1. WritePropertyValues("", db.Entry(book).CurrentValues);

EF框架step by step(6)—处理实体complex属性的更多相关文章

  1. EF Core中怎么实现自动更新实体的属性值到数据库

    我们在开发系统的时候,经常会遇到这种需求数据库表中的行被更新时需要自动更新某些列. 数据库 比如下面的Person表有一列UpdateTime,这列数据要求在行被更新后自动更新为系统的当前时间. Pe ...

  2. EF框架step by step(7)—Code First DataAnnotations(1)

    Data annotation特性是在.NET 3.5中引进的,给ASP.NET web应用中的类提供了一种添加验证的方式.Code First允许你使用代码来建立实体框架模型,同时允许用Data a ...

  3. 不用EF框架,完成完美实体映射,且便于维护!(AutoMapper,petapoco)

    最近,需要搭建一个新项目,在需求分析时确定数据库中需要创建多个存储过程.所以如果还是用原来EF框架生成ADO.net实体模型的话,不利于修改. 主要是解决以下两个问题: 1.比如前端需要一个值,如果存 ...

  4. 释怀我的诺亚尔 不用EF框架,完成完美实体映射,且便于维护!(AutoMapper,petapoco)

    释怀我的诺亚尔   不用EF框架,完成完美实体映射,且便于维护!(AutoMapper,petapoco) 最近,需要搭建一个新项目,在需求分析时确定数据库中需要创建多个存储过程.所以如果还是用原来E ...

  5. EF框架step by step(5)—处理实体简单属性

    EF框架会对实体进行跟踪,对实体的每个属性当前值和原始值及其状态进行跟踪,记录.当前值是指实体属性当前的被赋予的值,而原始值是指实体最初从数据库读取或者附加到DbContext时的值. 先通过简单的代 ...

  6. EF框架step by step(7)—Code First DataAnnotations(2)

    上一篇EF框架step by step(7)—Code First DataAnnotations(1)描述了实体内部的采用数据特性描述与表的关系.这一篇将用DataAnnotations描述一下实体 ...

  7. EF框架step by step(8)—Code First DataAnnotations(2)

    上一篇EF框架step by step(7)—Code First DataAnnotations(1)描述了实体内部的采用数据特性描述与表的关系.这一篇将用DataAnnotations描述一下实体 ...

  8. EF框架step by step(3)—Code-First

    CodeFirst是EF框架的第三种方式,也是最为复杂一种方式,本文将以EF4.1版本为基础,简要讲解一下用法,同时,也介绍DbContext的用法. 本文采用的示例仍然是前两篇采用的博客用户的示例. ...

  9. EF框架step by step(2)—Model-First

    这一篇主要说一下EF框架中,Model First做法,仍然采用上一篇的案例.但增加评论功能.首先打开Blog.edmx文件,在空白处右键,添加新实体Comment,如下图示: 点击确定,关闭窗口. ...

随机推荐

  1. SQL TO LINQ(Linqer神器)

    此软件可以把SQL语句转换成LINQ语句 首先把Linqer下载到本地, 1.在VS中创建.dbml文件和.cs文件 打开VS,创建一个控制台项目即可,再添加一个dbml项目 2.添加连接数据库 3. ...

  2. Oracle dbms_lock.sleep()存储过程使用技巧-场景-分析-实例

    <Oracle dbms_lock.sleep()存储过程使用技巧>-场景-分析-实例 摘要:今天是2014年3月10日,北京,雾霾,下午组织相关部门开会.会议的结尾一名开发工程师找到了我 ...

  3. C 工厂模式 还有其他的模式

    http://blog.csdn.net/feixiaoxing/article/details/7081243

  4. hadoop 2.5 hdfs namenode –format 出错Usage: java NameNode [-backup] |

    在 cd  /home/hadoop/hadoop-2.5.2/bin 下 执行的./hdfs namenode -format 报错[hadoop@node1 bin]$ ./hdfs nameno ...

  5. 关于logcat日志

    最近学习android,碰到了logcat,个人总结一下. 当不出日志是解决办法: ProjectMenu---后台设置----LOG设置---LOG开关 Logcat(deprecated)和Log ...

  6. 20145206邹京儒《Java程序设计》第4周学习总结

    20145206 <Java程序设计>第4周学习总结 教材学习内容总结 第六章 6.1 何谓继承 继承基本上就是避免多个类间重复定义共同行为 package cc.openhome; pu ...

  7. myaql常用函数

    一.数学函数 abs(x)   返回x的绝对值 bin(x)   返回x的二进制(oct返回八进制,hex返回十六进制) ceiling(x)   返回大于x的最小整数值 exp(x)   返回值e( ...

  8. bootstratp图标的使用

    bootstratp作为一个优秀的前端框架,最近使用了其中的Glyphicon Halflings的字体图标.起初一直显示不出来,后面通过搜索相关资料直到成功显示,在此做一些总结,方便后面复习. 1. ...

  9. Genymotion

    @Genymotion相关文件下载地址 http://pan.baidu.com/s/1nu9nReh @虚拟机网络代理设置 Normal 0 7.8 磅 0 2 false false false ...

  10. EasyUi – 4.datagrid

    测试的时候用Json来测试就好啦. <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> ...