[置顶] 【EF系列】ModelFirst实体优先

一、前言

      在前文中我们介绍了DBFirst,它要求要现有数据库, 然后通过EF映射创建实体。非常简单易学。下面给大家介绍另外一种——ModelFirst,实体优先。

二、内容介绍

      Model First 是先利用某些工具(如VS的EF设计器)设计出可视化的实体数据模型及他们之间的关系,然后再根据这些实体、关系去生成数据库对象及相关代码文件。
      通过实战演练来更好的展示:

三、实战演练

首先打开VS2012 ,选择控制台程序:

[置顶] 【EF系列】ModelFirst实体优先_第1张图片

                                                    图一 选择控制台程序

第一步 添加实体

然后在项目中添加ADO实体模型:

[置顶] 【EF系列】ModelFirst实体优先_第2张图片

                                                   图二 选择ADO实体模型

[置顶] 【EF系列】ModelFirst实体优先_第3张图片

                                                   图三 选择ADO实体模型

选择模型类型: 这里我们选择“空EF设计器模型”,有的版本也叫做“空模型”。

[置顶] 【EF系列】ModelFirst实体优先_第4张图片

                                                   图四 选择模型类型

点击完成后,生成的界面:

[置顶] 【EF系列】ModelFirst实体优先_第5张图片

                                                    图五 生成的界面

在模型设计视图中,添加新实体:

                                                    图六 添加新实体

[置顶] 【EF系列】ModelFirst实体优先_第6张图片

                                                    图七 添加新实体

                                                    图八 添加新实体

添加实体的属性,属性分为三种:标量属性,导航属性,复杂属性。这三种属性会在下文给大家介绍。这里我们使用标量属性,生成新属性后,选中属性,点击F4,可以设置内容。

                                                    图九 设置属性

按照同样的方法,再创建一个实体。

[置顶] 【EF系列】ModelFirst实体优先_第7张图片

                                                    图十 再创建一个实体

接下来添加二者之间的关系,“user”和“card”是一对多的关系。 右击user,点击新增,关联。

[置顶] 【EF系列】ModelFirst实体优先_第8张图片

                                                    图十一 添加关系

选择合适的关系:

                                                    图十二 选择合适的关系 

添加完关系后的效果图:

[置顶] 【EF系列】ModelFirst实体优先_第9张图片

                                                    图十三  关系后的效果图

第二步 根据模型生成数据库

确保数据库中已经存在一个空白数据库,这里我用代码建立了一个空的数据库,名字叫做EFModelFirst。

                                                    图十四  空白数据库

下面就需要生成到数据库了,在模型设计视图空白处选择“根据模型生成到数据库…”:

[置顶] 【EF系列】ModelFirst实体优先_第10张图片

                                                    图十五 根据模型生成到数据库

相信大家对这个界面不陌生吧!

[置顶] 【EF系列】ModelFirst实体优先_第11张图片

                                                    图十六 根据模型生成到数据库

                                                    图十七 选择数据库数据库

                                                    图十八 添加链接字符串

[置顶] 【EF系列】ModelFirst实体优先_第12张图片

                                                    图十九 选择EF模型

[置顶] 【EF系列】ModelFirst实体优先_第13张图片

生成数据库向导:

[置顶] 【EF系列】ModelFirst实体优先_第14张图片

                                                    图二十 生成数据库向导

然后再点击完成即可,看到生成的Sql脚本:

[置顶] 【EF系列】ModelFirst实体优先_第15张图片

                                                    图二十一 生成数据库SQL脚本

在空白处点击右键,选择执行,生成数据库:

                                                    图二十二  执行,生成数据库

第三步 增删改查

在类中写如下代码:

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.Entity;
using System.Data.Entity.Validation;


namespace EFModelFirst
{
    class Program { static void Main(string[] args) { #region 添加数据 //1.声明上下文 ModelFirstModelContainer dbContext = new ModelFirstModelContainer(); //2.对数据库的操作,添加数据 //2.1 实例化实体,对实体赋值 user u = new user(); u.Id = 1; u.Name = "Ares"; u.CreateDate = DateTime.Now; //2.2 增 //实体附加到上下文 dbContext.userSet.Attach(u); //添加到数据库 dbContext.Entry(u).State = EntityState.Added; //3. 保存 dbContext.SaveChanges(); #endregion #region 查看数据库数据 //方法一、使用 Linq 语句查询 card c = new card(); //1.Linq 语句 var item = from s in dbContext.cardSet select s; //遍历查询出来的内容 foreach (var cardid in item) { Console.WriteLine("Linq查询Id结果是:" + cardid.Id); } //方法二、使用lambda查询 var itemlambda = dbContext.cardSet.Where<card>(s => s.Id == 2).FirstOrDefault(); Console.WriteLine("lambda查询Id结果是:" + itemlambda.Id); #endregion } } } 

执行结果:

四、小结

     通过这次的介绍,我们知道了可以通过Model实体来创建数据库,非常好的选择,希望能给大家带来帮助。下一篇会向大家介绍CodeFirst。

你可能感兴趣的:(数据库,数据,对象,设计,可视化)