現在的位置: 首頁 > 綜合 > 正文

讀取資料庫數據返回OleDbDataReader函數(Access)

2018年04月10日 ⁄ 綜合 ⁄ 共 2131字 ⁄ 字型大小 評論關閉
    // 讀取資料庫數據返回OleDbDataReader函數(Access)
    public OleDbDataReader GetOleDbReader(String MySQL)
    {
        // 資料庫連接參數(對客戶端應用程序配置文件的訪問)
        string strConn = @ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString;
        // 創建連接資料庫的一個打開連接
        OleDbConnection MyConn = new OleDbConnection(strConn);
        try // 正常運行
        {
            // 使用 ConnectionString 所指定的屬性設置打開資料庫連接
            MyConn.Open();
            // 資料庫SQL語句
            String strSQL = @MySQL.Trim().ToString();
            // 要對資料庫執行的一個SQL語句或存儲過程
            OleDbCommand MyComm = new OleDbCommand(strSQL, MyConn);
            // 提供一種從資料庫讀取只進的行流的一種方式
            OleDbDataReader MyReader = MyComm.ExecuteReader();
            // 讀取數據,判斷是否有數據
            if (MyReader.HasRows)
            {
                // 返回成功
                return MyReader;
            }
            else
            {
                Console.Write("<script language=JavaScript>");
                Console.Write("alert('系統提示:數據讀取失敗或網路忙,請稍後再試!');");
                Console.Write("</script>");
                if ((MyReader != null) & (MyReader.IsClosed != true))
                {
                    // 關閉
                    MyReader.Close();
                }
                // 判斷資料庫連接
                if (MyConn.State == ConnectionState.Open)
                {
                    // 關閉資料庫連接
                    MyConn.Close();
                }
                // 返回失敗
                return null;
            }
        }
        catch (SqlException) // 資料庫操作異常處理
        {
            Console.Write("<script language=JavaScript>");
            Console.Write("alert('系統提示:當前資料庫操作失敗或網路忙,請稍後再試!');");
            Console.Write("</script>");
            if (MyConn.State == ConnectionState.Open)
            {
                // 關閉資料庫連接
                MyConn.Close();
            }
            // 返回失敗
            return null;
        }
        catch // 異常處理
        {
            if (MyConn.State == ConnectionState.Open)
            {
                // 關閉資料庫連接
                MyConn.Close();
            }
            // 返回失敗
            return null;
        }
     finally // 執行完畢清除在try塊中分配的任何資源
        {
            if (MyConn.State == ConnectionState.Open)
            {
                // 關閉資料庫連接
                //MyConn.Close();
            }
        }
    } 

抱歉!評論已關閉.