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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...