C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
數(shù)據(jù)庫的訪問是所有編程語言中最重要的部分,C#提供了ADO.Net部件用于對數(shù)據(jù)庫進行訪問。我們將從最簡單易用的微軟Access數(shù)據(jù)庫入手討論在C#中對數(shù)據(jù)庫的訪問。
C#中的Connection對象和Command對象與Access類似,但在這里我們還將使用其另一個與RecordSet類似的被稱作ADODataReader的對象,它負責處理與查詢有關的RecordSet對象。
首先,必須使用微軟的Access創(chuàng)建一個數(shù)據(jù)庫。運行Access,創(chuàng)建一個數(shù)據(jù)庫,但不要創(chuàng)建任何表(我們將在下面的程序中創(chuàng)建表。),保存創(chuàng)建的數(shù)據(jù)庫。
打開控制面板中的ODBC圖標,點擊System DNS標簽,依次選擇Add>Microsoft Access,并點擊Finish按鈕。在拉下來的對話框中輸入數(shù)據(jù)源的名字,比如是mymdb,然后創(chuàng)建數(shù)據(jù)源,雙擊OK按鈕。
在下面的程序中,我們將創(chuàng)建一個表,并在其中插入一些值。
程序非常地簡單和直觀。在Main()函數(shù)中,ADOConnection對象將數(shù)據(jù)源的名字取到構造器中,然后使用ADOConenction的Open()方法打開該連接。
在連接建立后,程序將創(chuàng)建包含二個字段的表a1,其中字段name的類型為字符型,vno的類型為整型。Create table命令已經(jīng)放在ADOCommand的構造器中,ExecuteNonQuery()方法用于執(zhí)行這一查詢,該方法不會返回任何記錄集。同樣,Insert和Delete查詢也可以放到ADOCommand的Constructor中,因此可以象在VB中那樣傳遞任何SQL查詢。
ADODataReader是新出現(xiàn)的,它是本段程序中主要的對象,負責處理ADOCommand返回的記錄集。使用xecute()方法,就可以看到從數(shù)據(jù)庫中返回的數(shù)據(jù)。ADODataReader的Read()方法則返回布爾型的值,TRUE標志著數(shù)據(jù)在ADODataReader對象中,而且將當前指針移動到了ADODataReader對象的下一條記錄上。
使用Visual Studio.Net 編譯下面的程序代碼。
namespace database1
{
using System;
using System.Data.ADO;
public class Class1
{
public Class1()
{
//
// 在這里添加Constructor的邏輯
//
}
public static int Main(string[] args)
{
try
{
ADOConnection s = new ADOConnection("Data Source=mymdb");
s.Open();
Console.WriteLine("Connection Established");
//創(chuàng)建表
Console.Write("Want to Create a Table?(y/n) ");
string ch = Console.ReadLine();
if (ch == "y")
{
ADOCommand CreateTable = new ADOCommand("Create Table a1(vno integer,name char(20))", s);
CreateTable.ExecuteNonQuery();
Console.WriteLine("AOCommand Executed / Table Created");
}
//在表中插入值
Console.Write("Want to Insert Some values in a Table?(y/n) ");
ch = Console.ReadLine();
if (ch == "y")
{
ADOCommand InsTable = new
ADOCommand("insert into a1 values(1, 'hi')", s);
InsTable.ExecuteNonQuery();
Console.WriteLine("Values Inserted");
}
//刪除整個表
Console.Write("Want to Delete All Records Present in the Table?(y/n) ");
ch = Console.ReadLine();
if (ch == "y")
{
ADOCommand DeleteTable = new ADOCommand("Delete from a1", s);
DeleteTable.ExecuteNonQuery();
Console.WriteLine("All Records Deleted From the Table");
}
//看所有記錄
Console.Write("Want to See all the Records Present in the Table /Database (y/n)? ");
ch = Console.ReadLine();
if (ch == "y")
{
ADOCommand AllRecs = new ADOCommand("select * from a1", s);
ADODataReader r;
AllRecs.Execute(out r);
while(r.Read())
{
for(int i=0; i < r.FieldCount;i++)
{
Console.Write(r.GetValue(i)+ " ");
}
Console.WriteLine();
}
Console.WriteLine("All Records Displayed");
r.Close();
}
s.Close();
Console.ReadLine();
}
catch(System.Exception e)
{
Console.WriteLine(e.ToString());
Console.ReadLine();
}
return 0;
} // Main函數(shù)結束
} // Class結束
}// 名字空間結束
以上就是 在C#中使用ADO.Net部件來訪問Access數(shù)據(jù)庫的過程,希望對大家的學習有所幫助。
相關文章
C#使用smtp發(fā)送帶附件的郵件實現(xiàn)方法
這篇文章主要介紹了C#使用smtp發(fā)送帶附件的郵件實現(xiàn)方法,可直接將string類型結果保存為附件,實例中備有相應的注釋便于理解,需要的朋友可以參考下2014-11-11
C# winfrom異步加載數(shù)據(jù)不影響窗體UI的操作方法
這篇文章主要介紹了C# winfrom 異步加載數(shù)據(jù)不影響窗體UI,在 WinForms 應用程序中,如果數(shù)據(jù)加載是一個比較耗時的操作,直接在主線程中進行加載會導致 UI 凍結,這是因為 WinForms 的 UI 是單線程的,主線程被阻塞時就無法處理其他 UI 相關的任務2024-12-12

