由于System.Data.OracleClient.dll从.NET Framework4.0之后已被弃用,所以我们无法在.NET Framework高版本中使用。一番搜索之后,发现好多文章提到.NET连接Oracle需要安装客户端,安装驱动,各种配置...感觉无比麻烦。

Oracle Entity Framework使用基本配置

Oracle官方推出了对于.NET的支持【Oracle Data Provider for .NET】,根据我的Visual Studio下载了一个对应版本的组件,安装很简单,没有什么选项。



安装完之后,可以通过Visual Studio创建个应用,然后来体验ODP.NET。

项目创建之后,选择添加组件【 ADO.NET实体对象模型】



跟随向导一路点击,这里我选择数据库先行



选择【新建一个连接】->选择【Oracle数据源】



配置数据库库连接属性,我们需要数据库的用户名、密码,连接方式选择EZ连接,然后写上你的数据库所在服务器的ip或者服务器主机名(注:数据库主机名和数据库服务名不是同一个东西),Oracle端口一般默认为1521



配置完成后,修改连接串的名字,当然这不是必要的



最后选择需要操作的数据库表、存储过程、视图...



等待vsiual studio将代码自动生成后,即可操作数据库访问

using (var dbContext=new OracleDbContext())
{
foreach (var item in dbContext.TMODALs)
{
Console.WriteLine("{0} {1}",item.C_ORG_CODE, item.C_USR_CODE);
}
}

Oracle.ManagedDataAccess

在ODP.NET中包含了Oracle.ManagedDataAccess.dll组件,它是.NET连接Oracle的驱动,有了它你不需要再安装Oracle数据库客户端软件就可以连接数据库。你可以通过Nuget直接安装这个dll组件



调用代码和其他数据库的写法没什么区别,只要注意连接串中数据库主机名(ip),数据库服务名,账号,密码只要配置好几本不会出什么问题。

 string connectionString = "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ZHYW)));Persist Security Info=True;User ID=root;Password=root;";
using (OracleConnection oracleConnection = new OracleConnection(connectionString))
{
oracleConnection.Open();
string cmdText = "SELECT * FROM TMODAL";
OracleCommand oracleCommand = new OracleCommand(cmdText,oracleConnection);
OracleDataReader oracleDataReader = oracleCommand.ExecuteReader();
if (oracleDataReader.HasRows)
{
while (oracleDataReader.Read())
{
Console.WriteLine("{0} {1}", oracleDataReader[0], oracleDataReader[1]);
}
}
}

常见的一些错误

server explore 中的连接"*****" 具有相同的身份证明



这是由于服务器资源管理器中已经存在该名字的连接,你可以通过【视图】->【服务器资源管理器】->【数据库】中把同名连接删除

ORA-12514:TNS:监听程序当前无法识别连接描述符中请求的服务



这个有可能是你的数据库服务名写错了,也就是数据库连接串中的SERVICE_NAME

Entity Framework入门教程:Oracle数据源访问的更多相关文章

  1. Entity Framework入门教程:SQLite数据源访问

    [环境安装] 可以通过NuGet直接搜索安装SQLite需要用到的组件 或者直接使用程序包管理器控制台 > Install-Package System.Data.SQLite 通过ADO.NE ...

  2. Entity Framework入门教程: Entity Framework支持的查询方式

    Entity Framework支持的查询方式有三种 LINQ to Entities Entity SQL Native SQL [LINQ to Entities] LINQ(语言集成查询)是从V ...

  3. Entity Framework入门教程(1)---Entity Framework简介

    什么是Entity Framework 学习EF的前提:熟练使用Linq和Ado.net,因为在使用EF框架进行开发时,我们大多数情况使用Linq进行查询和操作,而EF的底层实现用的是Ado.net. ...

  4. Entity Framework入门教程:什么是Entity Framework

    Entity Framework简介 Entity Framework是微软提供的一个O/RM(对象关系映射)框架.它基于ADO.NET,为开发人员提供了一种自动化的机制来访问和存储数据库中的数据. ...

  5. Entity Framework入门教程(8)---预先加载、延迟加载、显示加载

    1.预先加载 预先加载:在对一种类型的实体进行查询时,将相关的实体作为查询的一部分一起加载.预先加载可以使用Include()方法实现. 1.加载一个相关实体类型 栗子:使用Include()方法从数 ...

  6. Entity Framework入门教程(12)--- EF进行批量添加/删除

    EF6添加了批量添加/删除实体集合的方法,我们可以使用DbSet.AddRange()方法将实体集合添加到上下文,同时实体集合中的每一个实体的状态都标记为Added,在执行SaveChange()方法 ...

  7. ASP .NET MVC 之Entity Framework入门教程及源码

    本文主要的目的是 1. 说明Entity Framework Power Tools如何使用. 2. Entity Framework  快速门 实验环境: OS: Windows Server 20 ...

  8. Entity Framework入门教程:创建实体数据模型

    下图为一个已经创建好的数据库表关系 实体数据模型的创建过程 在Visual Studio项目中,右键程序集菜单,选择[添加]->[新建项],在[添加新项窗口]中选择[ADO.NET实体数据模型] ...

  9. Entity Framework入门教程(2)---EF工作流程

    EF工作流程 1.EF基本CRUD流程 下边的图就可以很清晰地展示EF的CRUD操作的基本工作流程: 这里做一个EF CRUD操作的简单总结:1.定义模型:这是EF工作的前提,定义模型包括定义领域类( ...

随机推荐

  1. 参数错误。 (异常来自 HRESULT:0x80070057 (E_INVALIDARG))

    异常来自 HRESULT:0x80070057 (E_INVALIDARG)未能加载程序集.......几次删除引用然后重新引用程序集还是报错 奔溃中....网上搜索还真有解决办法:解决方法 是 删除 ...

  2. 【使用WCF,发布服务端浏览报错】未能从程序集“System.ServiceModel, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089” 中加载类型 “System.ServiceModel.Activation.HttpModule”。

    问题: 在WIN7中的IIS服务器中部署WCF服务程序时,通过浏览器访问报出如下错误: 未能从程序集"System.ServiceModel, Version=3.0.0.0, Cultur ...

  3. 谈谈final, finally, finalize的区别

    final 修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承.因此一个类不能既被声明为 abstract的,又被声明为final的.将变量或方法声明为fi ...

  4. 教你做一个单机版人事管理系统(Winform版)treeview与listview使用详情

    ------------------------------------------------------------------部门部分------------------------------ ...

  5. 解决mydql执行sql文件时报Error: Unknown storage engine 'InnoDB'的错误。

    我运行了一个innoDB类型的sql文件,报了Error: Unknown storage engine 'InnoDB'错误,网上查了很多方法,但是都没办法真正解决我的问题,后来解决了,在这里总结一 ...

  6. (转)关于java.lang.UnsupportedClassVersionError解决方法总结

    背景:在服务器部署程序是后总是怀疑jdk安装不正确,所以打算运行一个小程序进行测试. 通过这样一个方法 ,可以测试jdk是否正确安装. 1 问题描述 首先编写了个Hello.java的代码: 这里我本 ...

  7. Spark No FileSystem for scheme file 解决方法

    在给代码带包成jar后,放到环境中运行出现如下错误: Exception in thread "main" java.io.IOException: No FileSystem f ...

  8. Redis-简单实现星形主从配置

    高级参考(https://www.zhihu.com/question/21419897) 简单应用场景 现在配置redis 星形 集群, 有三台服务器, 怎样实现? 复制redis.conf两份, ...

  9. Canvas 实现灵动的红鲤鱼动画(上)

    前言 上一篇文章<Canvas 仿百度贴吧客户端 loading 小球>实现了百度贴吧客户端的 loading 小球效果,同时还留下了一个任务:实现灵动的红鲤鱼动画. 这个动画效果实现起来 ...

  10. c语言链表升级

    之前的链表就是一个普通的带头的单向链表,我们不自觉的会发现这样的链表有缺陷,有关链表的删除新增查找跟链表的结构体内容耦合性太强 什么意思呢? 比如我们之前的链表的结构体 typedef struct ...