热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

一步一步学EntityFrameWork4(1)

本人在学习EF4时,读了很多书,走了很多弯路,最后发现其实EF4很简单,结合Linq,可以实现非常简单的添查删改操作。下面以一个实例为例对EF4的使用作一解析,希望大家在此少走弯路。本文采用较为成熟的

本人在学习EF4时,读了很多书,走了很多弯路,最后发现其实EF4很简单,结合Linq,可以实现非常简单的添查删改操作。下面以一个实例为例对EF4的使用作一解析,希望大家在此少走弯路。本文采用较为成熟的Database First模式,从数据库生成模型,然后使用T4模板生成POCO类代码,最后使用控制台程序进行调用。

1、数据库准备

本文选择的数据库是一个在实际工作中非常常用的数据库, 构造如下:

各个表的结构和数据类型如下:

  • ProductUnit表:产品单位

  • Products表:产品信息表

  • ProductBigType:产品大类

  • ProductSmallType:产品小类

依照上述步骤在Sql Server Management Studio编写完成后,就可以准备进行调用了。

2.准备相关工具

相信手边VS已经安装完毕,还要下载Entity Framework 4.x来进行安装,除此以外还需要一个重要的工具:

EF4.x POCO Entity Generator for C#,想要安装这一工具,点击VS的工具菜单下的扩展管理器,,,,在搜索框中搜索POCO字样就可以找到。这个工具实际上是一个T4模板,通过它可以为我们自动生成POCO式的实体类以及对ObjectContext的引用。

3、生成实体的POCO类

1)首先新建一个控制台项目,命名为ProdouctEFDemo;  

2) 在该项目的根结点上右键单击,在弹出的菜单里选择添加→新建文件夹,新建一个命名为Models的文件夹,数据模型将放在这里。

3)在Models文件夹上右键单击,在弹出的菜单里选择添加→新建项,在弹出的对话框中选择ADO.Net实体数据模型,并将其命名为ProductEFDemo.edmx;单击添加按钮继续;

pic7

image

4)选择“从数据库生成”,单击下一步继续;

image

5)点击新建连接,找到需要生成实体的数据库(这一步就不用演示了吧!)

注意勾选“将App.Config中的实体连接设置另存为”选项,本对话框中的ProductsEntities就是未来实体对象的类名,建议不要更改。观察一下实体连接字符串,哇好复杂,不用管他。操作完成后单击下一步继续:

image

6)选择全部的表,并注意勾选“在模型中加入外键列”,这一选项是EF4新增的,在实际应用中有很多好处,特别是在构建模型时,单击完成按钮就会在Models文件夹下生成实体数据模型:

注意检查VS的“输出”窗口,是否提示有生成错误等信息,如果有错误,就需要从“错误列表”窗口查看是什么出了错,一一解决。最常见的错误是表没有设置主键列,这会导致在进行数据插入时出现一些莫名其妙的错误,所以有关的检查在这一步都要完成,否则后面出了错很难调试。当然高手也可以通过手工悠edmx文件来解决(这个文件实际上就是一个XML文件),但是既然有可视化编辑器,为什么不让问题消失在萌芽中呢?

7)现在进入最高级的一步:生成实体类。VS默认已经有两个可供使用的实体类生成器,但个人觉得都不是很好用,没有生成POCO类,理解起来也困难。有了前面介绍的EF4.x POCO Entity Generator,问题迎刃而解。在VS中的ProductEFDemo.edmx的设计器界面任意的空白处点击右键,在弹出的菜单中选择“添加代码生成项”,在弹出的对话框选择EF4.x POCO Entity Generator,为其随便起一个名字:

image

点击添加后,Models文件夹下就出现了两个T4模板,并且同时自动运行T4生成器,为我们生成了所需要的实体POCO代码。你可以花一点时间研究一下这些代码,在这里因为篇幅原因,就不再拷贝代码了:
image

如果代码没有自动生成,可以在两个T4模板上分别点击左键,在弹出的菜单里选择“运行自定义工具”命令,可以得到同样的效果。

现在大功告成,可以动手进行我们的添查删改操作了。

4、向数据库添加测试数据:

为了简单起见,我们向数据库添加的数据符合这样的规则:如果字符串类型,内容为XX测试数据+序号,如果为decimal类型,内容为随机的double类型数据,如果是时间类型,内容为DateTime.Today;为此我们逐个向数据库添加数据,向数据库里添加数据的原则是:如果是一对多关系,先添加一的部分,再添加多的部分,否则多的部分会因为没有数据可用而引发异常,在本示例里,Product表是多的部分,而ProductUnit是一的部分,所以添加数据的顺序应为ProductUnit→ProductBigType→ProductSmallType→Product:

在项目中再添加一个文件夹,命名为Business,将我们进行添查删改的代码都放在里面,新建一个静态类InsertData,cs:

using System;using System.Collections.Generic;
using System.Linq;
using System.Text;
using ProductEFDemo.Models;

namespace ProductEFDemo.Business
{
public static class InsertData
{
public static void AddProudctUnit()
{
for (int i = 0; i <10; i++)
{
var productUnit = new ProductUnit
{
ProductUnitId=Guid.NewGuid(),
ProductUnitName = String.Format("产品单位测试数据{0}",i.ToString())
};
using (var ctx = new ProductsEntities())
{
ctx.ProductUnit.AddObject(productUnit);
ctx.SaveChanges();
}

}

}
}
}

好了,基本的ProductUnit的数据录入问题得到圆满解决。这里对代码作一个解释:

在命名空间务必要添加对ProductEFDemo.Models的引用,因为实体的POCO类,ObjectContext类都在这呢!

然后就可以自由地调用相关的类了,注意这句:

using (var ctx = new ProductsEntities()) { ctx.ProductUnit.AddObject(productUnit); ctx.SaveChanges(); }

适用于所有情况,其中ctx是ObjectContext类的实例,调用AddObject方法就可以将对象加入ObjectContext,然后再调用SaveChanges方法就可以将数据更新到数据库。是不是很简单?

如法泡制:

  public static void AddProductBigType()
{
for (int i = 0; i <10; i++)
{
var productBigType = new ProductBigType
{
ProductBigTypeId = Guid.NewGuid(),
ProductBigTypeName = String.Format("产品大类测试数据{0}", i.ToString())
};
using (var ctx = new ProductsEntities())
{
ctx.ProductBigType.AddObject(productBigType);
ctx.SaveChanges();
}

}
}

       public static void AddProductSmallType(Guid productBigTypeId)
{
for (int i = 0; i <10; i++)
{
var productSmallType = new ProductSmallType
{
ProductBigTypeId=productBigTypeId,
ProductSmallTypeId=Guid.NewGuid(),
ProductSmallTypeName = String.Format("产品小类测试数据{0}", i.ToString())
};
using (var ctx = new ProductsEntities())
{
ctx.ProductSmallType.AddObject(productSmallType);
ctx.SaveChanges();
}
}
}

public static void AddProduct(Guid productUnitId,Guid productSmallTypeId)
{
for (int i = 0; i <10; i++)
{
var rand = new Random();
var product = new Product()
{
ProductId=Guid.NewGuid(),
ProductName=string.Format ("产品名称测试数据{0}",i.ToString()),
ProductSmallTypeId=productSmallTypeId,
ProductUnitId=productUnitId,
ProductBasePrice=(decimal)(rand.NextDouble()*100),
ProductLosePrice=(decimal)(rand.NextDouble()*50)
};
using (var ctx = new ProductsEntities())
{
ctx.Product.AddObject(product);
ctx.SaveChanges();
}
}
}
SQL表生成代码下载:
/Files/qouoww/sql.zip

声明:本文系本人原创,版权归属作者和博客园共同所有,任何组织或个人不得随意转载,修改。需要转载请与本人联系:qouoww@163.com。

 


推荐阅读
  • 本文介绍了在实现了System.Collections.Generic.IDictionary接口的泛型字典类中如何使用foreach循环来枚举字典中的键值对。同时还讨论了非泛型字典类和泛型字典类在foreach循环中使用的不同类型,以及使用KeyValuePair类型在foreach循环中枚举泛型字典类的优势。阅读本文可以帮助您更好地理解泛型字典类的使用和性能优化。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文详细介绍了使用C#实现Word模版打印的方案。包括添加COM引用、新建Word操作类、开启Word进程、加载模版文件等步骤。通过该方案可以实现C#对Word文档的打印功能。 ... [详细]
  • 开发笔记:spring boot项目打成war包部署到服务器的步骤与注意事项
    本文介绍了将spring boot项目打成war包并部署到服务器的步骤与注意事项。通过本文的学习,读者可以了解到如何将spring boot项目打包成war包,并成功地部署到服务器上。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 图片复制到服务器 方向变了_双服务器热备更新配置文件步骤问题及解决方法
    本文介绍了在将图片复制到服务器并进行方向变换的过程中,双服务器热备更新配置文件所出现的问题及解决方法。通过停止所有服务、更新配置、重启服务等操作,可以避免数据中断和操作不规范导致的问题。同时还提到了注意事项,如Avimet版本的差异以及配置文件和批处理文件的存放路径等。通过严格执行切换步骤,可以成功进行更新操作。 ... [详细]
author-avatar
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有