Model First 是先利用某些工具(如VS的EF设计器)设计出可视化的实体数据模型及他们之间的关系,然后再根据这些实体、关系去生成数据库对象及相关代码文件。
一、设计实体数据模型,生成数据库
1、创建空的EF实体模型
2.设计需要的实体
这里需要说明标量属性即常规字段,导航属性一般自动生成,复杂属性是向表里写数据,是插一个实体。按F4可以操作字段的属性。
3.添加关联
这里就涉及导航属性的自动添加。注意多对多关系是不会产生外键,但是会产生一张中间表,这张中间表是存放多对多的数据明细。
4.根据模型生成数据库
之后会生成sql脚本。
其中CustomerProduct这张表就是多对多关联产生的中间表,我们来看下表的字段
虽然能自动生成多对多关系的中间表,我们也可以自己去设计中间表。中间表和另外两张表的关系都是多对一。在一般的工作中,都会通过自己定义中间表,而不是自动生成自动表。
二、Model First生成后的文件
基本和DB First相同。
三、CRUD操作
CRUD的基本操作和DB First没有什么变化,这里就随便写个插入操作
Model1Container dbContext = new Model1Container(); Customer cus = new Customer();
cus.Id = ;
cus.CusName = "cus2"; List<OrderInfo> oiList = new List<OrderInfo>();
OrderInfo oi1 = new OrderInfo { Id = , OrderContent = "订单1",CustomerId = };
OrderInfo oi2 = new OrderInfo { Id = , OrderContent = "订单2", CustomerId = };
oiList.Add(oi1);
oiList.Add(oi2); List<Product> proList = new List<Product>();
Product pro1 = new Product { Id = , ProName = "产品1" };
Product pro2 = new Product { Id = , ProName = "产品2" };
proList.Add(pro1);
proList.Add(pro2); dbContext.Customer.Add(cus);
foreach (var oi in oiList)
{
dbContext.OrderInfo.Add(oi);
}
foreach (var pro in proList)
{
dbContext.Product.Add(pro);
}
dbContext.SaveChanges();
查询
Model1Container dbContext = new Model1Container(); Customer cus1 = dbContext.Customer.Where(p => p.Id == ).ToList().FirstOrDefault();
List<OrderInfo> oiList = new List<OrderInfo>();
oiList = cus1.OrderInfo.ToList();
foreach (var oi in oiList)
{
Console.WriteLine(oi.OrderContent);
}