转载于:http://blog.csdn.net/zhoukun1008/article/details/50528145

现在越来越喜欢MVC了,不光是因为ITOO中用到了他,而是因为它里面包含了很多的知识点让我们去学习,我们的ITOO在服务端用到了EF和WCF,而对于MVC来说,他也可以与EF合作操作数据库,也可以像WebForm一样为用户显示数据。下面我总结一下用DBFirst来创建实体数据库模型。

1、新建ASP.NET MVC 4 Web 应用程序

2、创建空的模板

3、创建ADO.net实体数据模型(在Model文件件下右击——>添加——>新建项——>数据——>ADO.Net实体数据模型)

4、选择来自数据的EF设计器(这里选择的就是DBFirst)

5、点击新建连接,创建新的数据连接。

6、填入服务器名称(可以是自己你的IP,也可以是自己的用户名,我这里用“.”来代替,代表本地)

7、继续点击下一步,选择实体框架的版本。

8、导入适当的表【视图、存储过程和函数】,我这里只导入了表。点击完成就OK了。

9、对象关系映射

上面的几部操作完成后,右击edmx文件,选择打开方式,用XML(文本)编辑器打开。这样,我们就可以看见数据库中的表与C#中的实体类中的数据,以及他们是如何映射的啦!

    看一下这个XML文件的主要组成吧!

首先是数据库中BlogArticleCate表的数据

  1. <EntityType Name="BlogArticleCate">
  2. <Key>
  3. <PropertyRef Name="Id" />
  4. </Key>
  5. <Property Name="Id" Type="int" StoreGeneratedPattern="Identity" Nullable="false" />
  6. <Property Name="Author" Type="int" Nullable="false" />
  7. <Property Name="Name" Type="nvarchar" MaxLength="50" Nullable="false" />
  8. <Property Name="Remark" Type="nvarchar" MaxLength="200" />
  9. <Property Name="Statu" Type="int" Nullable="false" />
  10. <Property Name="IsDel" Type="bit" Nullable="false" />
  11. <Property Name="Addtime" Type="datetime" Nullable="false" />
  12. </EntityType>

Csharp中BlogArticleCate实体类的数据

  1. <EntityType Name="BlogArticleCate">
  2. <Key>
  3. <PropertyRef Name="Id" />
  4. </Key>
  5. <Property Name="Id" Type="Int32" Nullable="false" annotation:StoreGeneratedPattern="Identity" />
  6. <Property Name="Author" Type="Int32" Nullable="false" />
  7. <Property Name="Name" Type="String" MaxLength="50" FixedLength="false" Unicode="true" Nullable="false" />
  8. <Property Name="Remark" Type="String" MaxLength="200" FixedLength="false" Unicode="true" />
  9. <Property Name="Statu" Type="Int32" Nullable="false" />
  10. <Property Name="IsDel" Type="Boolean" Nullable="false" />
  11. <Property Name="Addtime" Type="DateTime" Nullable="false" Precision="3" />
  12. <NavigationProperty Name="BlogArticles" Relationship="Self.FK_BlogArticle_BlogArticleCate" FromRole="BlogArticleCate" ToRole="BlogArticle" />
  13. <NavigationProperty Name="BlogUser" Relationship="Self.FK_BlogArticleCate_BlogUser" FromRole="BlogArticleCate" ToRole="BlogUser" />
  14. </EntityType>

数据库中的表与实体之间的对应关系

  1. <EntitySetMapping Name="BlogArticleCates">
  2. <EntityTypeMapping TypeName="OumindBlogModel.BlogArticleCate">
  3. <MappingFragment StoreEntitySet="BlogArticleCate">
  4. <ScalarProperty Name="Id" ColumnName="Id" />
  5. <ScalarProperty Name="Author" ColumnName="Author" />
  6. <ScalarProperty Name="Name" ColumnName="Name" />
  7. <ScalarProperty Name="Remark" ColumnName="Remark" />
  8. <ScalarProperty Name="Statu" ColumnName="Statu" />
  9. <ScalarProperty Name="IsDel" ColumnName="IsDel" />
  10. <ScalarProperty Name="Addtime" ColumnName="Addtime" />
  11. </MappingFragment>
  12. </EntityTypeMapping>
  13. </EntitySetMapping>

看看上面的对应的关系,一个实体类中的属性相对应着数据库表中的一个字段,还有他们分别在C#类中、表中各自的数据类型。正是有了上面的一一对应关系,我才明白:当我们用EF操作实体类中的数据的时候,EF为什么能将实体中“属性”的数据映射到表中的“字段”里面去的。

《MVC+EF》——用DBFirst创建ADO.NET实体数据模型和对象关系映射的更多相关文章

  1. Visual 2015创建新项,缺少ADO.NET 实体数据模型的解决方法

    现在的某度查资料真的很麻烦,突然我自身的VS2015创建EF的时候找不到 ADO.NET 实体数据模型,但是使用CodeFrist是可以生成数据表的.所有特别郁闷. 打开界面如下 某度半天,都没有查出 ...

  2. Model First:创建实体数据模型(ADO.NET 实体数据模型)

    Microsoft Entity Framework是一个对象关系映射工具(Object Relational Mapping ,O/RM)工具.它可以让你从一个数据库自动地生成数据接入层.实体框架免 ...

  3. vs212创建mvc3项目,添加ADO.NET实体数据模型时产生 XXXX.Desiger.cs 文件为空

    vs212创建mvc3项目,发现添加ADO.NET实体数据模型时,产生StoreDB.Desiger.cs文件为空 产生StoreDB.Desiger.cs文件为空 原因是,在vs2012中,添加AD ...

  4. 连接SQLite 创建ADO.net实体类

    0.开发环境 win10,vs2013-x64 1.安装: sqlite-netFx451-setup-bundle-x86-2013-1.0.102.0.exe 注意事项:选在VisualStudi ...

  5. Entity Framework (EF) Core工具创建一对多和多对多的关系

     一. EntirtyFramework(EF)简介 EntirtyFramework框架是一个轻量级的可扩展版本的流行实体框架数据访问技术,微软官方提供的ORM工具让开发人员节省数据库访问的代码时间 ...

  6. ADO.NET实体数据模型使用探索1

    今天研究了下ADO.NET实体数据模型,想写个关于两张有外键关系的增改删查,以此来稍增加点难度. 编程环境:vs2010+sql2005 1.在SQL2005下建立三张表:学生信息表Student(S ...

  7. Visual Studio2017中如何让Entity Framework工具【ADO.NET实体数据模型】支持MYSQL数据源

    熟悉Entity Framework应该对以下图片不陌生,他就是ADO.NET实体数据模型向导:可以将数据库的表自动生成模型类,或者创建Code First的模型文件. 但是这个模型向导默认只显示微软 ...

  8. ADO.NET实体数据模型中关于数据库字段默认值的处理

    无论是Visual Studio 2010或者2013内置的ADO.NET实体数据模型都有一个小问题:数据库中有些字段已设置了默认值,但ADO.NET实体数据模型工具并不会自动进行设置. 这时需要手工 ...

  9. Visual Studio2017中如何让ADO.NET实体数据模型[EntityFramework]支持MariaDB&MySQL数据源

    近期由于工作需要,需要重新修改设计系统的ADO.NET实体数据模型.edmx文件中间,在完成实际中途遇到一些实际使用问题,特此记录. 1. Visual Studio 2017 无法以实体设计模式打开 ...

随机推荐

  1. Windows下的Jdk 1.8*安装并配置(图文详解)

    不多说,直接上干货! 简单说下,jdk1.8*的下载,见http://www.cnblogs.com/zlslch/p/5658383.html 双击jdk-8u60-windows-x64.exe运 ...

  2. 如何让你的网站用上免费的HTTPS

    因为之前网站上被注入了广告,再百般尝试之后最后还是使用了HTTPS解决了. 在实现HTTPS的时候最关键的就是证书. 证书的质量觉得了你被多少浏览器所信任. 证书的价格也就蹭蹭蹭往上涨了. 这里推荐一 ...

  3. Redis注意事项

    1.Redis3.0没有虚拟内存概念,已从2.4就移除: 2.redis挂掉并重启时,如果有主从备份的,主机挂掉重启时先关掉主从备份,不然从机的数据会被冲洗掉 数据恢复时如果有 AOF(原理是将Rei ...

  4. redis使用watch秒杀抢购思路

    1.使用watch,采用乐观锁 2.不使用悲观锁,因为等待时间非常长,响应慢 3.不使用队列,因为并发量会让队列内存瞬间升高 测试代码: import java.util.concurrent.Exe ...

  5. es6学习笔记8--Map数据结构

    Map Map结构的目的和基本用法 JavaScript的对象(Object),本质上是键值对的集合(Hash结构),但是只能用字符串当作键.这给它的使用带来了很大的限制. var data = {} ...

  6. dom操作------创建节点/插入节点

    <section> <div id="box" style="position: relative;"> <p id=" ...

  7. Docker镜像的获取和推送

    查找镜像 查找镜像的方法有主要有两种,一种是在Docker Hub官方网站查找,网址为https://hub.docker.com/ 另一种方法是在命令行界面中通过docker serach < ...

  8. Spring源码分析:Bean加载流程概览及配置文件读取

    很多朋友可能想看Spring源码,但是不知道应当如何入手去看,这个可以理解:Java开发者通常从事的都是Java Web的工作,对于程序员来说,一个Web项目用到Spring,只是配置一下配置文件而已 ...

  9. 二叉搜索树(hdu3791)

    二叉搜索树 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  10. 如何在Eclipse中修改Git项目

    第一步:先在Eclipse创建一个要上传的项目. 第二步:创建一个Git仓库并与远程仓库相连 第三步:将Eclipse创建的项目复制到创建好的Git仓库 第四步:将Eclipse新建项目删除重新imp ...