EF外键关联
客户里面存在客服外键
基类模型
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外键关联的更多相关文章
- 基于EF的数据外键关联查询
现在很多ORM不自带外键关联的实体查询,比如我查询用户,用时将关联的角色信息查询出来,那么就要进行2次查询,很麻烦.而我现在要做的就是基于EF的外键关联查询.很方便的. 首先,创建基础查询的BaseS ...
- Entity FrameWork对有外键关联的数据表的添加操作
前天做了一个MVC Entity FrameWork项目,遇到有外键关联的数据编辑问题.当你编辑的时候,按照正常的逻辑,把每个字段的数据都对号入座了,然后点击保存按钮,本以为会顺理成章的编辑数据,但是 ...
- Entity Framework - 理清关系 - 基于外键关联的单向一对一关系
注:本文针对的是 Entity Framework Code First 场景. 之前写过三篇文章试图理清Entity Framework中的一对一关系(单相思(单向一对一), 两情相悦(双向一对 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (29) ------ 第五章 加载实体和导航属性之过滤预先加载的实体集合和修改外键关联
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-13 过滤预先加载的实体集合 问题 你想过滤预先加载的实体集合,另外,你想使用 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (37) ------ 第六章 继承与建模高级应用之独立关联与外键关联
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 6-13 在基类中应用条件 问题 你想从一个已存在的模型中的实体派生一个新的实体, ...
- Entity Framework Code First添加修改及删除外键关联实体
1.添加外键关联实体 1>.添加新的Province及City实体 using (var ctx = new PortalContext()) { var city1 = new City { ...
- Hibernate5.2之一对一外键关联(五)
Hibernate5.2之一对一外键关联(五) 一.简介 上篇文章中笔者介绍了Hibernate关联关 ...
- 【Python】django模型models的外键关联使用
Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...
- hibernate一对一双向外键关联
一对一双向外键关联:双方都持有对方的外键关联关系. 主控方和一对一单向外键关联的情况是一样的,主要的差异表现为,被空方需要添加: @OneToOne(mappedBy="card" ...
随机推荐
- 转 @html.ActionLink的几种参数格式
一 Html.ActionLink("linkText","actionName") 该重载的第一个参数是该链接要显示的文字,第二个参数是对应的控制器的方法, ...
- 【原】redis插件安装
wget -c https://github.com/nicolasff/phpredis/archive/2.2.4.tar.gz -O phpredis-2.2.4.tar.gz tar xzf ...
- a链接事件点击函数
<script> <!-- function ChangeStarCommunity(o){ var o = document.getElementById(o); if( docu ...
- ant 介绍 http://blog.csdn.net/sunjavaduke/archive/2007/03/08/1523819.aspx
转自: 本内容包含了Ant的历史简要介绍,Ant的功能以及Ant框架的介绍,并对下载安装使用Ant进行了示例介绍,同时通过一个Java程序讲解了Ant的基本使用方法. 1. Ant简介:这 ...
- java技术 spring 配置
spring 的IOC是反射注入,用来管理对象的创建与销毁.一般使用都是在启动的web服务器的时候就创建了对象,可以选择自动装配对象管理,将对象引用实现与引用分开.采用的xml配置方式.及大减少了各个 ...
- 用 pyvenv 创建几个不相互影响的python虚拟环境
IN MY UBUNTU python2的环境控制: sudo apt-get install virtualenv 创建: virtualenv --no-site-packages [环境搭建目 ...
- Spring对 JDBC 的支持,JdbcTemplate类的使用
导包:spring框架的包 和 连接数据库连接池的c3p0包 连接mysql数据库的包; 在src目录下建立jdbc.properties文件:存放连接数据库的属性值 jdbc.user=root j ...
- Neo4j创建自动索引
一.创建Neo4j的Legacy indexing 1.为节点创建索引 官方API的创建示例为: 将一节点添加至索引: public static void AddNodeIndex(String n ...
- 关于Python3爬虫抓取网页Unicode
import urllib.requestresponse = urllib.request.urlopen('http://www.baidu.com')html = response.read() ...
- Effective objective-c 2.0阅读笔记
这本书非常的好,看完后,感触挺深,总结纪录一下,针对ios开发的备忘: 注:分类和原著有些不同,自己总结学习用的,仅供参考. 系统篇: 了解oc起源:继承c,由Smalltalk演化而来.动态语言 ...