EFModelFirst实体优先

Posted AresCarry

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EFModelFirst实体优先相关的知识,希望对你有一定的参考价值。

一、前言

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

二、内容介绍

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

三、实战演练

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

这里写图片描述

                                                    图一 选择控制台程序

第一步 添加实体

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

这里写图片描述

                                                   图二 选择ADO实体模型

这里写图片描述

                                                   图三 选择ADO实体模型

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

这里写图片描述

                                                   图四 选择模型类型

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

这里写图片描述

                                                    图五 生成的界面

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

这里写图片描述

                                                    图六 添加新实体

这里写图片描述

                                                    图七 添加新实体

这里写图片描述

                                                    图八 添加新实体

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

这里写图片描述

                                                    图九 设置属性

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

这里写图片描述

                                                    图十 再创建一个实体

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

这里写图片描述

                                                    图十一 添加关系

选择合适的关系:

这里写图片描述

                                                    图十二 选择合适的关系 

添加完关系后的效果图:

这里写图片描述

                                                    图十三  关系后的效果图

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

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

这里写图片描述

                                                    图十四  空白数据库

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

这里写图片描述

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

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

这里写图片描述

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

这里写图片描述

                                                    图十七 选择数据库数据库

这里写图片描述

                                                    图十八 添加链接字符串

这里写图片描述

                                                    图十九 选择EF模型

这里写图片描述

生成数据库向导:

这里写图片描述

                                                    图二十 生成数据库向导

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

这里写图片描述

                                                    图二十一 生成数据库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

以上是关于EFModelFirst实体优先的主要内容,如果未能解决你的问题,请参考以下文章

实体框架和代码优先开发

实体框架代码优先 - 保存实体时设置属性的最佳方法是啥

实体框架代码优先 - 通过主键将子实体添加到父实体

使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段

实体框架代码优先 IQueryable

实体框架、代码优先和全文搜索