国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Access > 正文

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

2024-09-07 19:04:22
字體:
來源:轉載
供稿:網友

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

共2頁上一頁12下一頁
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 文水县| 高要市| 邯郸县| 湾仔区| 临澧县| 高碑店市| 平度市| 咸丰县| 襄樊市| 泽普县| 泌阳县| 庆城县| 无锡市| 永平县| 建湖县| 芷江| 拜泉县| 诸城市| 玛多县| 卫辉市| 通江县| 富顺县| 民权县| 莱州市| 崇文区| 白玉县| 福安市| 石屏县| 海宁市| 霍城县| 罗田县| 巩义市| 奎屯市| 开原市| 凤阳县| 漳浦县| 彰化县| 宜兰市| 湘乡市| 陆河县| 道真|