Dapper學習 - Dapper的基本用法(二) - 存儲過程/函數

来源:http://www.cnblogs.com/elvinle/archive/2016/11/11/6053064.html
-Advertisement-
Play Games

上一篇貌似少介紹了自定義函數和存儲過程, 因為這兩個也可以使用查詢的方式來實現功能, 這一篇就補上 一、自定義函數的創建和調用 (mysql的) 註意在mysql中, delimiter $$ 這個的使用, 起一個分割功能, 有些編譯器中, 如果不寫這個, 是不會把這些當做方法,存儲過程去處理的, ...


上一篇貌似少介紹了自定義函數和存儲過程, 因為這兩個也可以使用查詢的方式來實現功能, 這一篇就補上

 一、自定義函數的創建和調用 (mysql的)

Delimiter $$
drop function if exists func_test;
CREATE FUNCTION func_test (idIn INT) RETURNS int
BEGIN
DECLARE res int DEFAULT 0;
select count(1) into res from tch_teacher where id > idIn ;
return res;
END $$
Delimiter ;

註意在mysql中, delimiter $$ 這個的使用, 起一個分割功能, 有些編譯器中, 如果不寫這個, 是不會把這些當做方法,存儲過程去處理的, 而是當做普通查詢語句, 會報錯的.

以下是調用方法:

//方法一 : 直接寫sql, 然後用Query調用
sql = "select func_test(@id);";
var res = conn.Query<int>(sql, new { id = 10 }).FirstOrDefault();  //90
Console.WriteLine("Count = " + res); //Count = 90

//方法二 : 直接用Query方法, 傳入函數名, 參數, 但是註意要把CommondType設置為StoredProcedure
//而且調用的時候, 是必須要有 Return參數的, 否則會報錯
var para = new  DynamicParameters();
para.Add("@idIn", 20);
para.Add("@res", 0, DbType.Int32, ParameterDirection.ReturnValue);
var res1 = conn.Query("func_test", para, null, true, null, CommandType.StoredProcedure).FirstOrDefault();  //0
Console.WriteLine("Query @res = " + para.Get<int>("@res"));  //Query @res = 80

//方法三 : 使用Execute方法也是可以的, 要註意加一個返回參數
var param = new DynamicParameters();
param.Add("@idIn", 25);
param.Add("@res", 0, DbType.Int32, ParameterDirection.ReturnValue);
var res2 = conn.Execute("func_test", param, null, null, CommandType.StoredProcedure);  //0
Console.WriteLine("Execute @res = " + param.Get<int>("@res"));  //Execute @res = 75

一般來說, 我習慣使用方法一, 比較方便, 因為函數這裡並沒有返回參數, 在使用時, 不需要在sql中定義參數, 然後執行. 方法一是很方便的

此種方法在調用存儲過程的時候也可以符合部分情況. 請看下麵分解

 

二、存儲過程的創建和調用

Delimiter $$
drop PROCEDURE if EXISTS pro_test;
create PROCEDURE pro_test(in idIn int)
begin
select count(1) as Count from tch_teacher where id > idIn;
end $$
Delimiter ;

Delimiter $$
drop PROCEDURE if EXISTS pro_test1;
create PROCEDURE pro_test1(in idIn int, out count int)
begin
select count(1) into count from tch_teacher where id > idIn;
select * from tch_teacher where id > idIn;
end $$
Delimiter ;

call pro_test(11);

set @count =0;
call pro_test1(11, @count);
select @count;

 

這裡我創建了兩個存儲過程, 一個是有返回參數的, 另一個並沒有.

//方法一
sql = "call pro_test(@id);";
var res = conn.Query<int>(sql, new { id = 15 }).FirstOrDefault();  //85
Console.WriteLine("res = " + res);  //res = 85

//方法二
var param = new DynamicParameters();
param.Add("@idIn", 20);
param.Add("@count", 0, DbType.Int32, ParameterDirection.Output);
var res2 = conn.Query<Tch_Teacher>("pro_test1", param, null, true, null, CommandType.StoredProcedure);//res2.Count = 80
Console.WriteLine("Query count = " + param.Get<object>("@count"));   //Query count = 80

//方法三
var res3 = conn.Execute("pro_test1", param, null, null, CommandType.StoredProcedure); //0
Console.WriteLine("Execute count = " + param.Get<object>("@count"));  //Execute count = 80

如果存儲過程有輸入參數, 那麼方法一併不適用, 會報錯的. Dapper解析到"@count"的時候, 會報錯.

所以, 對於存儲過程, 推薦適用方法二, 當然, 在沒有輸出參數的時候, 方法一更為簡單粗暴.

 


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

-Advertisement-
Play Games
更多相關文章
  • 由於一直在高校工作,就涉及到招生工作,招生時候又要收集學生圖像採集,所以就隨手寫了一個圖像採集工具,廢話不多說,進入正題。 圖像採集需要調用攝像頭就行拍照操作,網上查了一下資料,需要引用以下3個dll。 看一下運行界面 界面都比較low,主要是功能實現。 保存照片可以選擇自動覆蓋同名照片或者在照片中 ...
  • 目錄: 1.【C#Windows 服務】 《一》初入門 2.【C#Windows 服務】 《二》INI配置文件 一、工具: VS2015+NET Framework4.5。 二、操作: 1、創建INIHelp幫助類 2、豐富幫助類操作 3、windows實例調用 三、代碼: 1、INI幫助類: 2、 ...
  • 客戶端微信在二維碼狀態下,滑鼠滑過,會有一張手機的圖片滑動滑出,從隱藏到顯示,從顯示到隱藏。 思路很簡單:1、設置透明度;2、給個移動的位移 先看下做的效果 整體代碼也不難,就是給Image控制項設置動畫效果。 <Grid x:Name="grid_content" Background="White ...
  • 目錄結構 father |—— subfolder1 |—— subfolder2 當前在 subfolder1, 通過相對路徑的方式獲取 subfolder2的路徑 ...
  • 前言 最近做了一個電子政務的項目,其中用到了公文簽章和自定義報表,這兩個功能很常用,我就收集到自己的開發框架中了,同時也把實現方法分享給大家。 http://www.learun.cn:8090 線上demo 公文簽章 公文簽章是從網上找的一個JS小插件,原理很簡單,就是把印章放到一個div里,然後 ...
  • 【C#Windows 服務】 《一》初入門 目錄: 1.【C#Windows 服務】 《一》初入門 2.【C#Windows 服務】 《二》INI配置文件 一、工具: VS2015+NET Framework4.5。 二、操作: 1、新建windows服務的項目: 2、修改windows服務相關內容 ...
  • volatile多用於多線程的環境,當一個變數定義為volatile時,讀取這個變數的值時候每次都是從momery裡面讀取而不是從cache讀。這樣做是為了保證讀取該變數的信息都是最新的,而無論其他線程如何更新這個變數。 volatile多用於多線程的環境,當一個變數定義為volatile時,讀取這 ...
  • 摘要:VisualStuio2015 asp.net mvc如何引用ExtJS6,使用BundleConfig。 首先下載ExtJS6.0 gpl版。ExtJS有自己的程式框架,但我們需要asp.net mvc5,ExtJS只用作界面庫。 接下來要把下載好的ExtJS6的核心部分抽取出來,目錄結構是... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...