ADO.NET調用存儲過程

来源:http://www.cnblogs.com/yellowcool/archive/2017/08/21/7403421.html
-Advertisement-
Play Games

建表 創建儲存過程 調用 調用具有輸出參數的存儲過程 創建儲存過程 調用儲存過程 摘取至—————— 春華秋實 如侵自刪 ...


建表

CREATE TABLE [tab_cJ] (
[id] [int] IDENTITY (1, 1) NOT NULL PRIMARY KEY,
[name] [varchar] (50) ,
[age] [int] NULL ,
[info] [varchar] (200)
)

創建儲存過程

CREATE PROCEDURE QueryInfoByName
@name varchar(50),
@age int
AS
select info from tab_cj where [name]=@name and age=@age
GO

調用

using (SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=test;Integrated Security=True"))
        {
            SqlCommand cmd = conn.CreateCommand();
            cmd.CommandType = CommandType.StoredProcedure; //指定執行存儲過程操作
            cmd.CommandText = "QueryInfoByName"; //存儲過程名稱 
            //對應存儲過程QueryInfoByName的第一個參數@name
            SqlParameter parName = new SqlParameter("@name", SqlDbType.VarChar, 50);
            //指定參數@name要轉入的值
            parName.Value = "aa";
            //對應存儲過程QueryInfoByName的第二個參數@age
            SqlParameter parAge = new SqlParameter("@age", SqlDbType.Int);
            //指定參數@age要轉入的值
            parAge.Value = 12;

            //這一步非常重要,一定將設置好的兩個參數類型添加到Command對象的參數集合里
            cmd.Parameters.Add(parName);
            cmd.Parameters.Add(parAge);

            //方式一,查詢回來的結果需要顯示在DataGrid之類的控制項上
            DataSet ds = new DataSet();
            SqlDataAdapter adapter = new SqlDataAdapter(cmd);
            adapter.Fill(ds);

            //方式二,按單個值讀取 
            conn.Open();
            SqlDataReader reader = cmd.ExecuteReader();
            if (reader.HasRows)
            {
                while (reader.Read())
                {
                    Response.Write(reader.GetString(0));
                }
            }
        }

調用具有輸出參數的存儲過程

創建儲存過程

create procedure getAge
(
@name varchar(50),
@age int output
)
as
select @age=age from tab_cJ where [name]=@name

調用儲存過程

using (SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=test;Integrated Security=True"))
        {
            SqlCommand cmd = conn.CreateCommand();
            cmd.CommandType = CommandType.StoredProcedure; //指定執行存儲過程操作
            cmd.CommandText = "getAge"; //存儲過程名稱 
            SqlParameter parName = new SqlParameter("@name", SqlDbType.VarChar, 50);
            parName.Value = "aa";
            //對應存儲過程getAge的輸出參數@age
            SqlParameter parAge = new SqlParameter("@age", SqlDbType.Int);
            parAge.Direction = ParameterDirection.Output;
            cmd.Parameters.Add(parName);
            cmd.Parameters.Add(parAge);
            try
            {
                conn.Open();
                cmd.ExecuteNonQuery();
                int i = int.Parse(parAge.Value.ToString());
                Response.Write(i.ToString());
                conn.Close();
            }
            catch(Exception ex)
            {
                Response.Write(ex.ToString());
            }
            
        }

摘取至——————

春華秋實

如侵自刪


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

-Advertisement-
Play Games
更多相關文章
  • 使用XmlWriter寫Xml 假定創建了XmlWriter的實例變數xmlWriter,下文中將使用此實例變數寫Xml1.如何使用XmlWriter寫Xml文檔聲明 // WriteStartDocument方法可以接受一個bool參數(表示standalone,是否為獨立文檔)或者不指定參數st ...
  • 第 8 章:使用規範 8.1 數組 要在公共 API 中優先使用集合,避免使用數組。 不要使用只讀的數組欄位。雖然欄位本身是只讀的,用戶不能修改它們,但用戶可以修改數組中的元素。 考慮使用不規則數組,而不要使用多維數組。 8.2 修飾屬性 要在命名自定義修飾屬性類時添加“Attribute”尾碼。 ...
  • 18.1 使用定製特性 FCL 中的幾個常用定製特性. DllImport 特性應用於方法,告訴 CLR 該方法的實現位於指定 DLL 的非托管代碼中. Serializable 特性應用於類型,告訴序列化格式化器一個實例的欄位可以序列化和反序列化. AssemblyVersion 特性應用於程式集 ...
  • Adding Search to an ASP.NET Core MVC app 給程式添加搜索功能 2017-3-7 7 分鐘閱讀時長 作者 本文內容 1.Adding Search by genre 根據音樂流派添加搜索 2.Adding search by genre to the Index ...
  • WPF中的Style類似於Web應用程式中的CSS,它是控制項的一個屬性,屬於資源的一種。 ControlTemplate和DataTemplate區別: ControlTemplate用於改變控制項原來的形狀(一般定義在Style中,給控制項穿上一層新的外殼,改變這個控制項的外觀),而DataTempla ...
  • 針對barMange本身添加完背景色後右側區域無法填充問題 解決辦法: 添加standaloneBarDockControl控制項 1、在barMange屬性中附加standaloneBarDockControl這個控制項 2、設置standaloneBarDockControl的背景色 得到如下結果 ...
  • 隨筆分類 - .NET Core - dotNet實訓營 .Net Core 2.0 生態(1).NET Standard 2.0 特性介紹和使用指南 .Net Core 2.0 生態(2).NET Core 2.0 特性介紹和使用指南 .Net Core 2.0生態(3):ASP.NET Core ...
  • 安裝Erlang 1,安裝預環境 通過yum安裝以下組件。 2,下載Erlang並解壓 進入Erlang官網下載地址:http://www.erlang.org/downloads 需要註意的是,要找到與當前rabbitmq相容的版本:http://www.rabbitmq.com/which-er ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...