Entity Framework模型优先与实体对象查询
作者:springsnow 发布时间:2022-11-18 07:19:36
一、概念:
LINQ to Entities - ADO.NET | Microsoft 官方文档
EF实体框架目前版本为EF6。
EF6 可实现的功能:
不依赖于任何 EF 类型的 POCO 实体类的映射
自动更改跟踪
标识解析和工作单元
预先、延迟和显式加载
使用 LINQ(语言集成查询)转换强类型查询
丰富的映射功能,可支持:
一对一、一对多和多对多关系
继承(每个层次结构一张表、每个类型一张表和每个具体类一张表)
复杂类型
存储过程
通过可视化设计器创建实体模型。
通过编写代码创建实体模型的“Code First”体验。
既可从现有数据库生成模型,然后手动编辑,也可从头开始创建模型,然后用于生成新的数据库。
与 .NET Framework 应用程序模型(包括 ASP.NET)集成,并通过数据绑定与 WPF 和 WinForms 集成。
基于 ADO.NET 的数据库连接和可用于连接到 SQL Server、Oracle、MySQL、SQLite、PostgreSQL、DB2 等的众多提供程序。
官网文档:https://docs.microsoft.com/zh-cn/ef/ef6/
Database First(数据库优先):存在的DB----------->生成Data Model .edmx文件
Model First(模型优先):Data Model .edmx文件----------->生成DB DLL
POCO(plain Old CLR Object) 简单传统的CRL对象(持久性无感知),即普通类。
比较 EF Core 和 EF6:https://docs.microsoft.com/zh-cn/ef/efcore-and-ef6/
注意:EF Core 不支持对模型使用 EDMX 文件格式。 要移植这些模型,最佳方法是从应用程序的数据库中生成基于代码的新模型。
二、安装Entity Framework6
1、VS2019 Installer安装“Entity Framework6 工具”
使用 Entity Framework Tools,可以从现有数据库创建概念模型,然后以图形方式直观显示和编辑概念模型。
或者,您可以首先以图形方式创建概念模型,然后生成支持模型的数据库。
这些工具可生成或修改 .edmx文件。无论哪种情况,你都可以在基础数据库更改时自动更新模型,并为应用程序生成对象层代码。
2、通过Nuget安装“Entity Framework”:
三、新建ObjectContext 和EntityObject
“根据模型生成的数据库”的设计器功能实现ModelFirst。
通过设计器添加ADO.NET Entity Data Model项,GW.edmx生成代码:
逻辑层:由SSDL(存储架构定义语言)XML定义。底层:
概念层:由CSDL(概念架构定义语言)XML定义:顶层:
映射层:用MSL(映射规范语言)把CSDL中定义的实体类型定义映射到SSDL上。
Oracle设置项目属性:
DDL生成模板:SSDLToOracle.tt.
数据库架构名称:PAMS
数据库生成工作流:Generate Oracle Via T4(TPH)
注意:在Oracle的连接中选择“Filter”可以选中某个Schema,在选择后,如果创建edmx不生效,关掉VS重启即可。
可以增加或编辑“表映射”或”存储过程映射“,为当前选定的对象指定数据库表字段等映射。还可以为实体的每个属性指定并发模式。
注意:通过在设计器上添加更新的“存储过程映射”,当.NET尝试更新数据时,映射的存储过程对相应的每行更新。
默认生成DbContext和DBSet的方式:
public partial class AdventureWorks2012Entities : DbContext
{
public AdventureWorks2012Entities()
: base("name=AdventureWorks2012Entities")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
throw new UnintentionalCodeFirstException();
}
public virtual DbSet Person { get; set; }
}
四、实体对象查询:linq to Entities
1、使用lambda表达式查询
AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();
ObjectContext ctxObj = ((IObjectContextAdapter)ctx).ObjectContext;
ObjectSet objectSet = ctxObj.CreateObjectSet("Person");
IQueryable query1 = from e2 in objectSet//对象集
where e2.FirstName.StartsWith("A")
select e2;
foreach (var result in query1)
{
MessageBox.Show(result.FirstName);
}
2、执行存储过程(通过“添加”-----”函数导入“的设计器功能,添加到EDM实体数据模型)
自动生成:
public virtual int OutParam(ObjectParameter outp)
{
return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("OutParam", outp);
}
1)返回存储过程的输入输出参数。
AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();
ObjectParameter outpara = new ObjectParameter("outp", typeof(string));
ctx.OutParam(outpara);//OutParam为对应的存储过程名
MessageBox.Show(outpara.Value.ToString());
T-SQL存储过程:
create procedure Person.OutParam
@outp nvarchar output
as begin
set @outp='aa';
end;
Oracle存储过程:
create procedure pams.OutParam(outp out varchar2)
is
begin
outp:="aa";
end;
2)返回隐式结果集(在配置文件标记下面标记了返回类型。)
foreach (var result in ctx.update_and_returnSalary("T1", 24000))
{
Console.WriteLine(result.YGW_INT01);
}
Oracle存储过程:(T-SQL直接Select就行不用处理)
create procedure pams.update_and_returnSalary(
ID in varchar,sal in number,new_Salary out sys_refcursor
)
is
begin
update pams.YGW_CTRL set aaa;
open new_Salary for select YGW_INT01,YGW_LINE from pams.YGW_CTRL where aaa;
end;
五、App.conf文件
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="entityFramework"
type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
requirePermission="false"/>
For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468
<section name="oracle.manageddataaccess.client"
type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/>
</configSections>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/>
</startup>
<entityFramework>
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/>
</providers>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="mssqllocaldb"/>
</parameters>
</defaultConnectionFactory>
</entityFramework>
<connectionStrings>
<add name="AdventureWorks2012Entities"
connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string="data source=(LocalDb)\v11.0;initial catalog=AdventureWorks2012;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework""
providerName="System.Data.EntityClient"/>
</connectionStrings>
<system.data>
<DbProviderFactories>
<remove invariant="Oracle.ManagedDataAccess.Client"/>
<add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver"
type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/>
</DbProviderFactories>
</system.data>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<publisherPolicy apply="no"/>
<assemblyIdentity name="Oracle.ManagedDataAccess" publicKeyToken="89b483f429c47342" culture="neutral"/>
<bindingRedirect oldVersion="4.121.0.0 - 4.65535.65535.65535" newVersion="4.122.19.1"/>
</dependentAssembly>
</assemblyBinding>
</runtime>
<oracle.manageddataaccess.client>
<version number="*">
<dataSources>
<dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) "/>
</dataSources>
</version>
</oracle.manageddataaccess.client>
</configuration>
六、Oracle相关工具
下载:https://www.oracle.com/technetwork/topics/dotnet/products/index.html
Oracle Data Access Components:(装上可对VS提供Oracle的设计时支持) https://www.oracle.com/database/technologies/net-downloads.html
来源:https://www.cnblogs.com/springsnow/p/13230057.html
猜你喜欢
- Spring Boot FeignClient 捕获业务异常信息因项目重构采用spring cloud,feign不可避免。目前spring
- 概述RocketMQ 支持发送延迟消息,但不支持任意时间的延迟消息的设置,仅支持内置预设值的延迟时间间隔的延迟消息;预设值的延迟时间间隔为:
- 线性表是其组成元素间具有线性关系的一种数据结构,对线性表的基本操作主要有,获取元素,设置元素值,遍历,插入,删除,查找,替换,排序等。而线性
- 由于公司的开发团队偏向于使用Java技术,而且公司倡导学习开源技术,所以我选择用Java语言来进行Selenium WebDriver的自动
- javax.persistence中@Column定义字段类型在@Column中有个比较强大的配置 columnDefinition,如果有
- 本文实例讲述了JAVA设计模式之备忘录模式。分享给大家供大家参考,具体如下:备忘录模式:又叫做快照模式,指在不破坏封装性的前提下,获取到一个
- 实现HandlerInterceptor接口或者继承HandlerInterceptor的子类,比如Spring 已经提供的实现了Handl
- Java 里的 * 是动态拦截 action 调用的对象,它提供了一种机制可以使开发者可以定义在一个 action 执行的前后执行的代码,也
- java操作json对象出现StackOverflow错误今天在做项目的时候,遇到一个非常怪异的问题。一个java实体类中存在多个属性,每一
- 概述使用this()或target()可绑定被代理对象实例,在通过类实例名绑定对象时,还依然具有原来连接点匹配的功能,只不过类名是通过增强方
- Java代码package com.zzx.controller;import com.zzx.model.User;import org.
- Java是面向对象的编程语言,在我们开发Java应用的程序员的专业术语里,Java这个单词其实指的是Java开发工具,也就是JDK(Java
- 1、项目启动时报错如下Description:The bean 'securityManager', defined in
- 本文实例为大家分享了Java 1.8使用数组实现循环队列的具体代码,供大家参考,具体内容如下1、引入使用数组实现循环队列,功能如下:1)is
- 一、问题描述在接受 mq 消息的时候,需要做一个重试次数限制,如果超过 maxNum 就发邮件告警,不再重试。 所以我需
- 在Java中经常会涉及到对象数组的排序问题,那么就涉及到对象之间的比较问题。通常对象之间的比较可以从两个方面去看:第一个方面:对象的地址是否
- 1. 什么是AOPAOP (Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期 * 实现在
- 前言Kotlin一个强大之处就在于它的扩展函数,巧妙的运用这些扩展函数可以让你写出的代码更加优雅,阅读起来更加流畅,下面总结了在开发中经常用
- 使用datatables自带后台查询 前台代码:<!DOCTYPE html><html><head>&
- 1. 什么是对象池对象池,顾名思义就是一定数量的已经创建好的对象(Object)的集合。当需要创建对象时,先在池子中获取,如果池子中没有符合