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

        當(dāng)前位置:雨林木風(fēng)下載站 > 辦公軟件教程 > 詳細(xì)頁面

        運(yùn)用c#設(shè)置ACCESS數(shù)據(jù)庫

        運(yùn)用c#設(shè)置ACCESS數(shù)據(jù)庫

        更新時(shí)間:2022-05-08 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

        Microsoft Office Access是由微軟發(fā)布的關(guān)系數(shù)據(jù)庫管理系統(tǒng)。它結(jié)合了 MicrosoftJet Database Engine 和 圖形用戶界面兩項(xiàng)特點(diǎn),是 Microsoft Office 的系統(tǒng)程序之一。Microsoft Office Access是微軟把數(shù)據(jù)庫引擎的圖形用戶界面和軟件開發(fā)工具結(jié)合在一起的一個(gè)數(shù)據(jù)庫管理系統(tǒng)。它是微軟OFFICE的一個(gè)成員, 在包括專業(yè)版和更高版本的office版本里面被單獨(dú)出售。2018年9月25日,最新的微軟Office Access 2019在微軟Office 2019里發(fā)布。

           手頭沒有Microsoft Access,如何建立數(shù)據(jù)庫,一切依然簡(jiǎn)單.

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

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

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

          using System;

          using System.IO;

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

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

          public class Access

          ...{

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

          ///mdbPath:要?jiǎng)?chuàng)件的ACCESS絕對(duì)路徑

          public void Create( string mdbPath )

          ...{

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

          ...{

          throw new Exception("目標(biāo)數(shù)據(jù)庫已存在,無法創(chuàng)建");

          }

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

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

          // 創(chuàng)建一個(gè)CatalogClass對(duì)象的實(shí)例,

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

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

          cat.Create(mdbPath);

          }

          /**////壓縮修復(fù)ACCESS數(shù)據(jù)庫,mdbPath為數(shù)據(jù)庫絕對(duì)路徑

          public void Compact( string mdbPath )

          ...{

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

          ...{

          throw new Exception("目標(biāo)數(shù)據(jù)庫不存在,無法壓縮");

          }

          //聲明臨時(shí)數(shù)據(jù)庫的名稱

          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;

          //定義臨時(shí)數(shù)據(jù)庫的連接字符串

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

          //定義目標(biāo)數(shù)據(jù)庫的連接字符串

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

          //創(chuàng)建一個(gè)JetEngineClass對(duì)象的實(shí)例

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

          //使用JetEngineClass對(duì)象的CompactDatabase方法壓縮修復(fù)數(shù)據(jù)庫

          jt.CompactDatabase( mdbPath2, temp2 );

          //拷貝臨時(shí)數(shù)據(jù)庫到目標(biāo)數(shù)據(jù)庫(覆蓋)

          File.Copy( temp, mdbPath, true );

          //最后刪除臨時(shí)數(shù)據(jù)庫

          File.Delete( temp );

          }

          /**//// 備份數(shù)據(jù)庫,mdb1,源數(shù)據(jù)庫絕對(duì)路徑; mdb2: 目標(biāo)數(shù)據(jù)庫絕對(duì)路徑

          public void Backup( string mdb1, string mdb2 )

          ...{

          if( !File.Exists(mdb1) )

          ...{

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

          }

          try

          ...{

          File.Copy( mdb1, mdb2, true );

          }

          catch( IOException ixp )

          ...{

          throw new Exception(ixp.ToString());

          }

          }

          /**////恢復(fù)數(shù)據(jù)庫,mdb1為備份數(shù)據(jù)庫絕對(duì)路徑,mdb2為當(dāng)前數(shù)據(jù)庫絕對(duì)路徑

          public void Recover( string mdb1, string mdb2 )

          ...{

          if( !File.Exists(mdb1) )

          ...{

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

          }

          try

          ...{

          File.Copy( mdb1, mdb2, true );

          }

          catch( IOException ixp )

          ...{

          throw new Exception(ixp.ToString());

          }

          }

          }

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

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

          System.Data Namespace

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

          如果想講清楚這些東西,我不認(rèn)為是我可以作到的,所以我想通過一些具體的程序來把我們對(duì)數(shù)據(jù)庫的最基本的操作(SELECT、UPDATE、DELETE、INSERT等)演示一下,其他的還是需要朋友們?cè)趯W(xué)習(xí)過程中來慢慢體會(huì)了!

          要想操作一個(gè)數(shù)據(jù)庫,不論是那種操作,首先要做的肯定是打開數(shù)據(jù)庫,下面我們以ACCESS數(shù)據(jù)庫來做例子說明如何打開一個(gè)數(shù)據(jù)庫連接!在這里我們需要用到的是:System.Data.OleDb.OleDbConnection類!(如果操作SQL數(shù)據(jù)庫,我們最好使用 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的朋友應(yīng)該都可以看懂的!我們先定義一個(gè)String類型的變量,其中存放了我們連接數(shù)據(jù)庫的連接字符串,然后在定義一個(gè) System.Data.OleDb.OleDbConnection類型的對(duì)象并實(shí)例化,最后返回這個(gè)對(duì)象!需要說明一下的是,我并沒有把語句: tempconn.Open();放到這個(gè)函數(shù)中,原因我我稍后在說明,這里只是先提醒一下!

          通過上面的函數(shù),我們就已經(jīng)得到了類似于ADO中的連接對(duì)象Connection了!下面的就是具體操作數(shù)據(jù)庫了!

          在具體講操作前,我認(rèn)為有必要先認(rèn)識(shí)一下下面的兩個(gè)類:

          System.Data.OleDb.OleDbDataAdapter

          System.Data.OleDb.OleDbDataReader

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

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

                :更多精彩教程請(qǐng)關(guān)注本文設(shè)計(jì)教程 欄目,


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

        溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

        本類教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 最新亚洲人成网站在线观看| 亚洲精品成人久久| 亚洲国产精品无码久久98| 99久久精品日本一区二区免费 | 亚洲不卡中文字幕| 亚洲精品免费在线| 亚洲欧洲自拍拍偷综合| av无码国产在线看免费网站| 亚洲一区二区三区免费视频| 人禽杂交18禁网站免费| 亚洲av成人中文无码专区| 国产国产人免费人成免费视频| 爱情岛论坛亚洲品质自拍视频网站| 国产高清免费在线| 亚洲国产免费综合| 亚洲电影一区二区三区| 日本zzzzwww大片免费| 亚洲欧美自偷自拍另类视| 免费真实播放国产乱子伦| 国产精品极品美女自在线观看免费| 日本亚洲国产一区二区三区| 性xxxx视频免费播放直播| 亚洲一区中文字幕在线电影网| 国产高清视频在线免费观看| 九九免费久久这里有精品23| 亚洲国产精品无码专区影院 | 国产真人无遮挡作爱免费视频| 疯狂做受xxxx高潮视频免费| 亚洲欧洲成人精品香蕉网| 成年在线观看网站免费| 国产亚洲精品国产福利在线观看| a级亚洲片精品久久久久久久| 91av免费观看| 免费人成大片在线观看播放| 亚洲av日韩av无码| 成人免费a级毛片| AAAAA级少妇高潮大片免费看| 亚洲午夜一区二区电影院| 亚洲综合精品网站| 在人线av无码免费高潮喷水| aa级女人大片喷水视频免费|