• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 辦公軟件教程 > 詳細頁面

        如何運用c#設置ACCESS數據庫

        如何運用c#設置ACCESS數據庫

        更新時間:2022-05-07 文章作者:未知 信息來源:網絡 閱讀次數:

        Microsoft Office Access是由微軟發布的關系數據庫管理系統。它結合了 MicrosoftJet Database Engine 和 圖形用戶界面兩項特點,是 Microsoft Office 的系統程序之一。Microsoft Office Access是微軟把數據庫引擎的圖形用戶界面和軟件開發工具結合在一起的一個數據庫管理系統。它是微軟OFFICE的一個成員, 在包括專業版和更高版本的office版本里面被單獨出售。2018年9月25日,最新的微軟Office Access 2019在微軟Office 2019里發布。

           如何使用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; //該命名空間包含創建ACCESS的類(方法)--解決方案 ==> 引用 ==> 添加引用 ==> 游覽找到.dll

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

          public class Access

          ...{

          /**////根據指定的文件名稱創建ACCESS數據庫

          ///mdbPath:要創件的ACCESS絕對路徑

          public void Create( string mdbPath )

          ...{

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

          ...{

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

          }

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

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

          // 創建一個CatalogClass對象的實例,

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

          // 使用CatalogClass對象的Create方法創建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;

          //創建一個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聯系,并操作數據源的,它的功能相對強大一些,因此也比較耗系統資源!

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


        Microsoft Access在很多地方得到廣泛使用,例如小型企業,大公司的部門。

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: a级毛片毛片免费观看久潮| 亚洲日韩中文字幕无码一区| jizz在线免费观看| 国产精品久久久久影院免费| 亚洲国产精品无码第一区二区三区 | 亚洲最大的成人网站| 国产h视频在线观看免费| 亚洲人成激情在线播放| 在线永久看片免费的视频| 99999久久久久久亚洲| 在线观看免费a∨网站| 亚洲aⅴ天堂av天堂无码麻豆| 国产精品99久久免费| 一区二区三区视频免费| 亚洲精品无码久久久久sm| 国产午夜精品久久久久免费视 | a级毛片视频免费观看| 久久久无码精品亚洲日韩京东传媒 | 免费a级毛片在线观看| 久久一区二区免费播放| 亚洲AV日韩精品久久久久| 1000部拍拍拍18勿入免费凤凰福利| 中文字幕在线观看亚洲| 成人免费无码视频在线网站| 99亚洲精品卡2卡三卡4卡2卡| 亚洲精品视频在线看| 国产成人一区二区三区视频免费| 91亚洲va在线天线va天堂va国产| 99re热免费精品视频观看 | 亚欧人成精品免费观看| 亚洲国产日韩a在线播放| 久久影院亚洲一区| 免费A级毛片无码专区| 亚洲国产精品18久久久久久| 亚洲AV无码乱码在线观看| 亚欧免费一级毛片| 亚洲成在人线在线播放无码| 亚洲人成亚洲人成在线观看 | 日本特黄特色AAA大片免费| 亚洲AV无码精品色午夜在线观看| 日本一区二区三区免费高清|