国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 禄丰县| 察雅县| 麻阳| 新安县| 苏尼特右旗| 丰县| 柏乡县| 繁昌县| 西藏| 留坝县| 灌南县| 汨罗市| 昌宁县| 旬邑县| 海门市| 济阳县| 丰顺县| 上思县| 浙江省| 留坝县| 井冈山市| 泗洪县| 江口县| 龙海市| 阳城县| 曲靖市| 通城县| 平安县| 沂水县| 临洮县| 德惠市| 衡南县| 仙居县| 新余市| 黎川县| 张家川| 靖江市| 屏山县| 望奎县| 平江县| 东阿县|