国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#中如何執(zhí)行存儲過程方法

2020-01-24 03:30:22
字體:
供稿:網(wǎng)友

功能 :  根據(jù)調(diào)用的方法名稱  反射動態(tài)調(diào)用  sql Command 的方法

復制代碼 代碼如下:

 /// <summary>
    /// 存儲過程的屬性
    /// ProcName 存儲過程的名稱
    /// MethodName 執(zhí)行SqlCommand 方法的名稱
    /// PrmList 存儲過程的參數(shù)
    /// </summary>
    public class ExeProc
    {
        public string ProcName;
        public string MethodName;
        public object[] PrmValue;
    }

根據(jù)制定的存儲過程的名稱

和參數(shù)  來執(zhí)行指定的存儲過程 和 調(diào)用 sqlCommand 的方法

復制代碼 代碼如下:

public class DataHelper
    {
        private string connString = null;
        public DataHelper(string conStr)
        {
            this.connString = conStr;
        }
        /// <summary>
        ///  執(zhí)行存儲過程
        /// </summary>
        /// <param name="ep">執(zhí)行存儲過程的屬性
        /// ProcName 存儲過程的名稱
        /// MethodName 執(zhí)行SqlCommand 方法的名稱
        /// PrmList 存儲過程的參數(shù)
        /// </param>
        /// <returns>返回執(zhí)行的結(jié)果</returns>
        public object ExecProcRetObj(ExeProc ep)
        {
            if (this.connString != null && this.connString != string.Empty)
            {
                try
                {
                    SqlConnection con = new SqlConnection(this.connString);
                    SqlCommand cmd = new SqlCommand();
                    cmd.Connection = con;
                    cmd.CommandText = "Exec " + ep.ProcName + " ";
                    foreach (object obj in ep.PrmValue)
                    {
                        cmd.CommandText += obj + ",";
                    }
                    cmd.CommandText = cmd.CommandText.Remove(cmd.CommandText.Length - 1, 1);
                    Type ty = cmd.GetType();
                    con.Open();

                    //用反射根據(jù)輸入的方法名 執(zhí)行對應的方法

                    object retObj = ty.InvokeMember(ep.MethodName, BindingFlags.InvokeMethod, null, cmd, null);
                    if (retObj.GetType().FullName == "System.Data.SqlClient.SqlDataReader")
                    {
                        //將返回的object 轉(zhuǎn)換成DataTable
                        DataTable retDt = new DataTable();
                        retDt.Load(retObj as SqlDataReader);
                        con.Close();
                        con.Dispose();
                        return retDt;
                    }

                    return retObj;
                }
                catch (Exception ex)
                {
                    System.Windows.Forms.MessageBox.Show("獲取數(shù)據(jù)發(fā)生錯誤/n" + ex.Message);
                }

            }
            return null;
        }
    }

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 北碚区| 霍林郭勒市| 滨州市| 南平市| 武穴市| 鸡东县| 三河市| 肥乡县| 谷城县| 巴青县| 海兴县| 连云港市| 开江县| 和政县| 特克斯县| 宜章县| 商河县| 古交市| 云龙县| 西充县| 全椒县| 新沂市| 江陵县| 固原市| 叙永县| 四子王旗| 织金县| 阳泉市| 石泉县| 桐梓县| 宁远县| 中方县| 舒兰市| 扎囊县| 汤阴县| 公安县| 易门县| 陈巴尔虎旗| 天长市| 保康县| 寿宁县|