客户里面存在客服外键

基类模型

public class ModelBase
{
public ModelBase()
{
CreateTime = DateTime.Now;
}
[Key]
public virtual int ID { get; set; }
public virtual DateTime CreateTime { get; set; }
}

客服模型

[Table("CustomerServer")]
public partial class CustomerServer : ModelBase
{
public string ServerId { get; set; } public string ServerName { get; set; } public string Email { get; set; }
public string Mobile { get; set; } public virtual List<Customer> CustomerManagerFor { get; set; } }

客户模型

[Table("Customer")]
public class Customer : ModelBase
{
[Required(ErrorMessage = "分支编号不能为空!"), MaxLength(, ErrorMessage = "分支编号不能超过4个字符!")]
public string BranchId { get; set; } [Required(ErrorMessage = "客户编号不能为空!"), MaxLength(, ErrorMessage = "客户编号不能超过10个字符!")]
public string CustomerId { get; set; } [Required(ErrorMessage = "客户姓名不能为空!"), MaxLength(, ErrorMessage = "客户姓名不能超过50个字符!")]
public string Name { get; set; } [Required(ErrorMessage = "性别不能为空!")]
public int Sex { get; set; } [Required(ErrorMessage = "生日不能为空!")]
public DateTime Birthday { get; set; } [Required(ErrorMessage = "资金账号不能为空!"), MaxLength(, ErrorMessage = "资金账号不能超过40个字符!")]
public string FundAccount { set; get; } [Required(ErrorMessage = "资产不能为空!")]
public decimal Assets { get; set; } [Required(ErrorMessage = "联系方式不能为空!"), MaxLength(, ErrorMessage = "联系方式不能超过40个字符!")]
public string Contact { get; set; } [Required(ErrorMessage = "地级市不能为空!")]
public int City { get; set; } [InverseProperty("CustomerManagerFor")]
[Required(ErrorMessage = "客户经理不能为空!")]
public virtual CustomerServer CustomerManager { get; set; } [Required(ErrorMessage = "开户日期不能为空!")]
public DateTime OpeningDate { get; set; } [Required(ErrorMessage = "风险类型不能为空!")]
public int RiskType { get; set; } [Required(ErrorMessage = "客户类型不能为空!")]
public int CustomerType { get; set; }
} [AttributeUsage(AttributeTargets.Property, AllowMultiple = false, Inherited = true)]
public class UniqueAttribute : ValidationAttribute
{
public override Boolean IsValid(Object value)
{
//校验数据库是否存在当前Key return true;
}
}

在上下文进行映射

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
Database.SetInitializer<CrmDbContext>(null);
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<Customer>().HasRequired(v => v.CustomerManager).WithMany(d => d.CustomerManagerFor).Map(v => v.MapKey("CustomerManager")).WillCascadeOnDelete(false);
}
    public DbSet<Customer> Customers { get; set; }
    public DbSet<CustomerServer> CustomerServers { get; set; }

查询

IQueryable<Customer> queryList = dbContext.Customers.Include("CustomerManager");

刚学EF,不懂要Include,查到的记录CustomerManager都是null,Include之后才有数据,在此标志一下

EF外键关联的更多相关文章

  1. 基于EF的数据外键关联查询

    现在很多ORM不自带外键关联的实体查询,比如我查询用户,用时将关联的角色信息查询出来,那么就要进行2次查询,很麻烦.而我现在要做的就是基于EF的外键关联查询.很方便的. 首先,创建基础查询的BaseS ...

  2. Entity FrameWork对有外键关联的数据表的添加操作

    前天做了一个MVC Entity FrameWork项目,遇到有外键关联的数据编辑问题.当你编辑的时候,按照正常的逻辑,把每个字段的数据都对号入座了,然后点击保存按钮,本以为会顺理成章的编辑数据,但是 ...

  3. Entity Framework - 理清关系 - 基于外键关联的单向一对一关系

      注:本文针对的是 Entity Framework Code First 场景. 之前写过三篇文章试图理清Entity Framework中的一对一关系(单相思(单向一对一), 两情相悦(双向一对 ...

  4. 《Entity Framework 6 Recipes》中文翻译系列 (29) ------ 第五章 加载实体和导航属性之过滤预先加载的实体集合和修改外键关联

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-13  过滤预先加载的实体集合 问题 你想过滤预先加载的实体集合,另外,你想使用 ...

  5. 《Entity Framework 6 Recipes》中文翻译系列 (37) ------ 第六章 继承与建模高级应用之独立关联与外键关联

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 6-13  在基类中应用条件 问题 你想从一个已存在的模型中的实体派生一个新的实体, ...

  6. Entity Framework Code First添加修改及删除外键关联实体

    1.添加外键关联实体 1>.添加新的Province及City实体 using (var ctx = new PortalContext()) { var city1 = new City { ...

  7. Hibernate5.2之一对一外键关联(五)

                                                     Hibernate5.2之一对一外键关联(五) 一.简介 上篇文章中笔者介绍了Hibernate关联关 ...

  8. 【Python】django模型models的外键关联使用

    Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...

  9. hibernate一对一双向外键关联

    一对一双向外键关联:双方都持有对方的外键关联关系. 主控方和一对一单向外键关联的情况是一样的,主要的差异表现为,被空方需要添加: @OneToOne(mappedBy="card" ...

随机推荐

  1. mysql成绩排名

    关于mysql成绩排名,网上大部分只是order by简单排序,忽略了成绩相同并列名次的问题. 定义了一个表score结构为:

  2. Unity3D 第一人称控制器 C#脚本

    CharacterMotor.cs using UnityEngine; using System.Collections; /** * @Author : www.xuanyusong.com */ ...

  3. 【转载】彻底卸载MYSQL的方法

    1.控制面板里的增加删除程序内进行删除 2.删除MySQL文件夹下的my.ini文件,如果备份好,可以直接将文件夹全部删除 3.开始->运行-> regedit 看看注册表里这几个地方删除 ...

  4. Geodatabase数据模型

    1  Geodatabase概念 Geodatabase是ArcInfo8引入的一种全新的面向对象的空间数据模型,是建立在DBMS之上的统一的.智能的空间数据模型.“统一”是指,Geodatabase ...

  5. mongoDB数据库和Spring MVC的整合

    之前一直用到的项目是Spring MVC+maven+mysql的,最近有些数据需要用到mongoDB数据库,现在做一些总结. 第一步:加载jar.maven配置 <!-- mongodb开始 ...

  6. linux mysql重装问题

    系统 :ubuntu16.04 使用apt-get命令安装mysql,启动时出错: can't connect to local mysql server through socket '/var/r ...

  7. leetcode-【中等题】Divide Two Integers

    题目 Divide two integers without using multiplication, division and mod operator. If it is overflow, r ...

  8. Debug 常见问题总结(持续更新)

    2016-9-24 1.for循环变量做参数一定要小心,嵌套一个for变量不要用同一个. 2.字符串处理要打好下标的草稿,不然很容易搞混.(方法待讨论). 3.整形比较比较容易忽略=的问题 ,> ...

  9. iOS 获取应用版本信息

    现在许多接口都需要上传应用版本信息,所以呢,这个是必不可少的,可以在进入应用的时候先获取到,然后存在单例中,用的时候直接调用单例就好了,记住这些字符串 NSString *executableFile ...

  10. 36、重新复习html和css之二

    (1)由于公司是意大利的网段, (2)而且公司的电脑是保密的, (3)文件发不出去, (4)U盘插不进去. (5)而且我们组的项目整体上已经开发完毕,客户暂时没有什么大的需求, 所以如果我不把这些技术 ...