午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    如何使用c#操作ACCESS數據庫
    來源:易賢網 閱讀:905 次 日期:2014-10-16 09:24:13
    溫馨提示:易賢網小編為您整理了“如何使用c#操作ACCESS數據庫”,方便廣大網友查閱!

    如何使用c#操作ACCESS數據庫:

    手頭沒有Microsoft Access,如何建立數據庫,一切依然簡單.

    首先引用C:Program FilesCommon FilesSystemadomsadox.dll,該DLL包含ADOX命名空間;

    接著引用C:Program FilesCommon FilesSystemadomsjro.dll,該DLL包含JRO命名空間

    SxS好問提示:如,導入dll不成功,手動把com組件導入為 .net組件,在用vs.net工具導入

    using System;

    using System.IO;

    using ADOX; //該命名空間包含創(chuàng)建ACCESS的類(方法)--解決方案 ==> 引用 ==> 添加引用 ==> 游覽找到.dll

    using JRO; //該命名空間包含壓縮ACCESS的類(方法)

    public class Access

    ...{

    /**////根據指定的文件名稱創(chuàng)建ACCESS數據庫

    ///mdbPath:要創(chuàng)件的ACCESS絕對路徑

    public void Create( string mdbPath )

    ...{

    if( File.Exists(mdbPath) ) //檢查數據庫是否已存在

    ...{

    throw new Exception("目標數據庫已存在,無法創(chuàng)建");

    }

    // 可以加上密碼,這樣創(chuàng)建后的數據庫必須輸入密碼后才能打開

    mdbPath = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;

    // 創(chuàng)建一個CatalogClass對象的實例,

    ADOX.CatalogClass cat = new ADOX.CatalogClass();

    // 使用CatalogClass對象的Create方法創(chuàng)建ACCESS數據庫

    cat.Create(mdbPath);

    }

    /**////壓縮修復ACCESS數據庫,mdbPath為數據庫絕對路徑

    public void Compact( string mdbPath )

    ...{

    if( !File.Exists(mdbPath) ) //檢查數據庫是否已存在

    ...{

    throw new Exception("目標數據庫不存在,無法壓縮");

    }

    //聲明臨時數據庫的名稱

    string temp = DateTime.Now.Year.ToString();

    temp += DateTime.Now.Month.ToString();

    temp += DateTime.Now.Day.ToString();

    temp += DateTime.Now.Hour.ToString();

    temp += DateTime.Now.Minute.ToString();

    temp += DateTime.Now.Second.ToString() + ".bak";

    temp = mdbPath.Substring(0, mdbPath.LastIndexOf("")+1) + temp;

    //定義臨時數據庫的連接字符串

    temp2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + temp;

    //定義目標數據庫的連接字符串

    mdbPath2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;

    //創(chuàng)建一個JetEngineClass對象的實例

    JRO.JetEngineClass jt = new JRO.JetEngineClass();

    //使用JetEngineClass對象的CompactDatabase方法壓縮修復數據庫

    jt.CompactDatabase( mdbPath2, temp2 );

    //拷貝臨時數據庫到目標數據庫(覆蓋)

    File.Copy( temp, mdbPath, true );

    //最后刪除臨時數據庫

    File.Delete( temp );

    } /**//// 備份數據庫,mdb1,源數據庫絕對路徑; mdb2: 目標數據庫絕對路徑

    public void Backup( string mdb1, string mdb2 )

    ...{

    if( !File.Exists(mdb1) )

    ...{

    throw new Exception("源數據庫不存在");

    }

    try

    ...{

    File.Copy( mdb1, mdb2, true );

    }

    catch( IOException ixp )

    ...{

    throw new Exception(ixp.ToString());

    }

    }

    /**////恢復數據庫,mdb1為備份數據庫絕對路徑,mdb2為當前數據庫絕對路徑

    public void Recover( string mdb1, string mdb2 )

    ...{

    if( !File.Exists(mdb1) )

    ...{

    throw new Exception("備份數據庫不存在");

    }

    try

    ...{

    File.Copy( mdb1, mdb2, true );

    }

    catch( IOException ixp )

    ...{

    throw new Exception(ixp.ToString());

    }

    }

    }

    ******************************************************************************************************

    在BETA2中,。NET提供了以下的NAMESPACE:

    System.Data Namespace

    System.Data.OleDb (和BETA1中已經不同了,所以如果拿BETA1中的程序到BETA2中來運行肯定不可以的)

    如果想講清楚這些東西,我不認為是我可以作到的,所以我想通過一些具體的程序來把我們對數據庫的最基本的操作(SELECT、UPDATE、DELETE、INSERT等)演示一下,其他的還是需要朋友們在學習過程中來慢慢體會了!

    要想操作一個數據庫,不論是那種操作,首先要做的肯定是打開數據庫,下面我們以ACCESS數據庫來做例子說明如何打開一個數據庫連接!在這里我們需要用到的是:System.Data.OleDb.OleDbConnection類!(如果操作SQL數據庫,我們最好使用 System.Data.SqlClient.SqlConnection類)

    我先寫出我自己使用的程序:

    using System.Data

    using System.Data.OleDb

    public OleDbConnection getConn()

    {

    string connstr="Provider=Microsoft.Jet.OLEDB.4.0 ;Data Source=F:webnotesbookclassleavenotes.mdb";

    OleDbConnection tempconn= new OleDbConnection(connstr);

    return(tempconn);

    }

    相信只要使用過ADO的朋友應該都可以看懂的!我們先定義一個String類型的變量,其中存放了我們連接數據庫的連接字符串,然后在定義一個 System.Data.OleDb.OleDbConnection類型的對象并實例化,最后返回這個對象!需要說明一下的是,我并沒有把語句: tempconn.Open();放到這個函數中,原因我我稍后在說明,這里只是先提醒一下!

    通過上面的函數,我們就已經得到了類似于ADO中的連接對象Connection了!下面的就是具體操作數據庫了!

    在具體講操作前,我認為有必要先認識一下下面的兩個類:

    System.Data.OleDb.OleDbDataAdapter

    System.Data.OleDb.OleDbDataReader

    System.Data.OleDb.OleDbDataAdapter:可以直接和DataSet聯(lián)系,并操作數據源的,它的功能相對強大一些,因此也比較耗系統(tǒng)資源!

    System.Data.OleDb.OleDbDataReader:則有些類似于ADO中的哪個只讀向前的記錄集,它最常用在只需要依次讀取并顯示數據的時候,相比 System.Data.OleDb.OleDbDataAdapter來說,他耗用的系統(tǒng)資源要小!其實,OleDbDataReader能實現的功能,OleDbDataAdapter都可以實現,不過從資源使用率的角度考慮我們應該盡量使用前者!但有些功能,卻是必須使用 OleDbDataAdapter才可以實現的!

    更多信息請查看IT技術專欄

    更多信息請查看數據庫
    易賢網手機網站地址:如何使用c#操作ACCESS數據庫

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網