Entity Framework 5.0.0 Function Import 以及 ODP. NET Implicit REF CURSOR Binding使用簡介

来源:http://www.cnblogs.com/yitouniu/archive/2016/02/26/5221180.html
-Advertisement-
Play Games

本文主要說明如何在Entity Framework 5.0.0中使用Function Import,以及使用ODP.NET的 Implicit REF CURSOR Binding功能。


源代碼

概要:1,明如何使用Entity Framework中的function import功能。

        2,說明如何使用ODP.NET的隱式REF CURSOR綁定(implicit REF CURSOR binding)。

 

環境以及工具:

Windows 10 企業版

Microsoft Visual Studio Enterprise 2015

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0

.NET Framework 4.0

ODP.NET(Nuget Package Id: Oracle.ManagedDataAccess; Nuget Package Version: 12.1.2400)

Entity Framework(Nuget Package Id: EntityFramework; Nuget Package Version: 5.0.0)

 

其他要求:Oracle資料庫中的HR schema訪問許可權。

 

1,創建一個Winform項目名稱為FunctionImportTest,.NET版本是4.0。

2, 打開Nuget Package Manager控制台。

  依次執行如下兩個命令分別安裝EF和ODP.NET的包:

  install-package -id EntityFramework -version 5.0.0 -projectname FunctionImportTest

  install-package -id Oracle.ManagedDataAccess -projectname FunctionImportTest

3,在Oracle資料庫中的HR方案裡面創建一個存儲過程。

  此存儲過程有一個類型為隱式游標變數的出參。

 1 CREATE OR REPLACE PROCEDURE "HR"."PROC_GET_EMP_BY_DEPT_NAME"
 2 (
 3     DEPT_NAME IN VARCHAR2 DEFAULT NULL,
 4     CUR_EMPS  OUT SYS_REFCURSOR
 5 ) AS
 6     SQL_STMT VARCHAR2(256) := 'SELECT t1.first_name, t1.last_name, t2.department_name FROM employees t1 ' ||
 7                               'JOIN departments t2 ON t1.department_id = t2.department_id ';
 8 BEGIN
 9     IF DEPT_NAME IS NOT NULL THEN
10         SQL_STMT := SQL_STMT || 'WHERE t2.department_name = ' || '''' || DEPT_NAME || '''';
11     END IF;
12 
13     OPEN CUR_EMPS FOR SQL_STMT;
14 END "PROC_GET_EMP_BY_DEPT_NAME";

4,從資料庫生成概念模型

(1),在項目名稱上點擊右鍵,選擇Add-->Add Item。選擇ADO.NET Entity Data Model,並把Name設置為HRModel,然後點擊Add。

 

(2),選擇從資料庫生成模型,點擊NEXT。

(3),選擇資料庫連接。本文使用Oracle資料庫中的HR方案。

(4),選擇Entity Framework版本。

(5),選擇資料庫對象及設置。選擇上文已經創建的HR.PROC_GET_EMP_BY_DEPT_NAME存儲過程,並點擊FINISH。

5,此時已經導入了Oracle中的存儲過程。然後把存儲過程的出參CUR_EMPS映射為具體的類。

導入之後的樣子如下圖所示:

6,配置app.config文件,設置存儲過程的隱式游標參數的元數據信息。

以下是app.config文件中oracle.manageddataaccess.client部分的配置。在設置屬性值時,VS基本都有提示。

 1 <oracle.manageddataaccess.client>
 2         <version number="*">
 3             <dataSources>
 4                 <dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) " />
 5             </dataSources>
 6             <implicitRefCursor>
 7                 <!-- 
 8                     註意:方案名稱和存儲過程的名稱是大小寫敏感的。
 9                     如果要保留方案名稱和存儲過程名稱中的小寫字母,則添加&quot;。
10                     例如<storedProcedure schema="&quot;SchemaName&quot;" name="&quot;StoredProcedureName&quot;">
11                     否則,EF框架會預設把這些名稱轉換為大寫形式。
12                 -->
13                 <storedProcedure schema="HR" name="PROC_GET_EMP_BY_DEPT_NAME">
14                     <!-- 游標參數的名稱是大小寫敏感的。 -->
15                     <refCursor name="CUR_EMPS">
16                         <bindInfo mode="Output"/>
17                         <!-- 參數的序數從0開始 -->
18                         <metadata columnName="FIRST_NAME" columnOrdinal="0" columnSize="20" nativeDataType="Varchar2" providerType="Varchar2" providerDBType="String" dataType="System.String" />
19                         <metadata columnName="LAST_NAME" columnOrdinal="1" columnSize="25" nativeDataType="Varchar2" providerType="Varchar2" providerDBType="String" dataType="System.String" />
20                         <metadata columnName="DEPARTMENT_NAME" columnOrdinal="2" columnSize="30" nativeDataType="Varchar2" providerType="Varchar2" providerDBType="String" dataType="System.String" />
21                     </refCursor>
22                 </storedProcedure>
23             </implicitRefCursor>
24         </version>
25     </oracle.manageddataaccess.client>

7,把函數導入映射為類型。

(1),修改function import。切換到Model Browser視窗。在Function Imports下麵剛纔導入的存儲過程名稱上點擊右鍵,然後點擊Edit。

(2),修改function import,並生成Complext Type。

① 修改Function Import Name。

② 選擇Returns a Collection Of下麵的Complex。

③ 點擊Get Column Information。

④ 點擊Create New Complex Type。

⑤ 把Complex Type的名稱修改為EmployeeBasicInfo。

⑥ 點擊OK。

此時,Complex Types下麵多了一個類型。

8,調用GetEmpByDeptName方法獲取數據,然後和DataGridView控制項綁定,把數據顯示出來。

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、serverCron簡介 在 Redis 中, 常規操作由 redis.c/serverCron 實現, 它主要執行以下操作 /* This is our timer interrupt, called server.hz times per second. * Here is where we
  • 要快點看論文了,寒假要看完的論文最後又是被拖到了最後幾天弄完../(ㄒoㄒ)/~~ 閑暇之時多記些linux命令,省著以後用再總去查了。 ************************************* 原文地址 CSDN(Linux小白學習入門過程): http://blog.csdn.
  • 在互聯網時代,網站就像一個公司的名片,擁有一個優秀的網站可以幫助企業樹立良好、可信的企業形象。其次,隨著網路經濟的發展,對於一些特殊的行業,企業網站還能夠為企業帶來直接的網路訂單。 本文介紹如何快速製作與發佈網站。製作網站一般選用HTML、CSS、JQuery語言,涉及後臺代碼才會運用到.NET、P
  • [hierarchyid] 是個不錯的數據類型,提供了很方便並且高性能的樹型查詢,網上找了很多資料都沒有講到如何做到動態插入這個關鍵點,從MSDN認真看了下資料寫出了一個DEMO CREATE TABLE EmployeeOrg ( OrgNode hierarchyid PRIMARY KEY C
  • 1.一個項目中的真實問題 實際項目中,本想通過C#製作小工具生成SHP的二進位空間索引文件,然後java服務端解析該空間索引文件進行使用。 在真實使用中發現java端解析的該文件內容與C#寫入的差別非常大,比如java中解析到的double均為非常大的負數。 2.排查問題 2.1 測試是否C#寫入有
  • 假設當前頁完整地址是:http://www.test.com/aaa/bbb.aspx?id=5&name=kelli "http://"是協議名 "www.test.com"是功能變數名稱 "aaa"是站點名 "bbb.aspx"是頁面名(文件名) "id=5&name=kelli"是參數 【1】獲取 完
  • System.Net.Http相關dll 報錯提示:500 Internal Server Error 測試站點上的問題,本地沒出現這個問題 後來經提醒,試了一下將sina所需要的dll都放進去,就成功了。 大概是因為引用sina的dll,其所需要的dll並沒有生成,發不上去後,bin文件下的dll
  • 老早就被各種推薦《CLR via C#》這本書了,然而一直沒去學。 因為工作中所需要的.NET功底目前算是足以應付了,而前端卻不熟,所以跑去學了一段時間前端的知識。 終於算是把前端方面的基礎學習計劃完成,工作中也完全有能力應付了,有時間來看看這本神書了。 依然像以前一樣買了本實體書,看了看,有700
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...