日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

如何使用c#操作ACCESS數(shù)據(jù)庫_Access數(shù)據(jù)庫教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:Access與MS SQL Server數(shù)據(jù)庫的相互轉(zhuǎn)換
一、將Access 數(shù)據(jù)庫數(shù)據(jù)移植轉(zhuǎn)換為sql server 2000 第一步,開啟SQLSERVER 2000服務(wù)管理,打開企業(yè)管理器,新建一個(gè)數(shù)據(jù)庫,名稱為Access數(shù)據(jù)轉(zhuǎn)換; 第二步,運(yùn)行導(dǎo)入和導(dǎo)出數(shù)據(jù),打開DTS導(dǎo)入/導(dǎo)出向?qū)�。選擇數(shù)據(jù)源時(shí),有兩種選擇:Driver do Microsoft Access(*.mdb)

   如何使用c#操作ACCESS數(shù)據(jù)庫:

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

  首先引用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)資源!

分享:兩個(gè)解決十萬條Access數(shù)據(jù)表分頁的方法
這篇文章主要介紹了Acess數(shù)據(jù)表分頁的兩個(gè)具體的解決方法,詳細(xì)內(nèi)容請(qǐng)參考下文。 后臺(tái)數(shù)據(jù)庫用是Access,客戶用了一年后說打開界面非常慢,查看了數(shù)據(jù)庫后發(fā)現(xiàn)數(shù)據(jù)表中的記錄已有五萬多條,自己試過將記錄復(fù)制到10 萬條,打開界面非常慢,翻頁也是同樣的問題,我采用的方式是

共2頁上一頁12下一頁
來源:模板無憂//所屬分類:Access數(shù)據(jù)庫教程/更新時(shí)間:2014-10-10
相關(guān)Access數(shù)據(jù)庫教程