天天看點

C# 通路資料庫

  C#通路資料庫無疑是非常友善的,下面給出了C#通路MSSQL的基本方法。

首先聲明命名空間using System.Data.SqlClient;

再使用SqlConnection類連接配接,SqlCommand類執行SQL指令,結果傳回給SqlDataReader類或其它類。

各類的基本用法介紹:

SqlConnection類

在構造時傳入連接配接資料庫字元串,也可以定義後通過ConnectionString屬性來設定。

用Open()連接配接資料庫,用Close()關閉連接配接。

SqlCommand類

在構造時傳入SQL指令和SqlConnection類對象,也可以定義後通過CommandText屬性和Connection屬性來設定。

執行SQL指令并得到結果                 SqlDataReader ExecuteReader()

執行SQL指令并得到受影響的行數    int ExecuteNonQuery()

SqlDataReader類

得到共有多少列          FieldCount屬性

得到第i列的列名         string GetName(int i)

得到第i列的資料類型  Type GetFieldType(int i)

判斷第i列是否為空     bool IsDBNull(int i)

得到第i列的資料        Object GetValue(int i)也可以直接sr[i].ToString()

前進到下一列            bool Read()

關閉                         void Close()

對于每個關聯的 SqlConnection,一次隻能打開一個 SqlDataReader,在第一個關閉之前,打開另一個的任何嘗試都将失敗。類似地,在使用 SqlDataReader 時,關聯的 SqlConnection 正忙于為它提供服務,直到調用 Close()時為止。

下面一些示例代碼:

//連接配接資料庫
string SQLCONNECT = @"server=PC-200907281720\SQLEXPRESS;database=master;uid=morewindows;pwd=12345";
SqlConnection conn = new SqlConnection(SQLCONNECT);
conn.Open();

//連接配接資料庫之後就可以執行SQL指令了
//使用SqlCommand類的ExecuteReader()傳回執行的結果
string SQLCOMMAND = "select CName, names, C4.LastLogin from C4, S4 where C4.LastLogin = S4.LastLogin order by CName, names";
SqlCommand sqlcmd = new SqlCommand(SQLCOMMAND, conn);
SqlDataReader sr = sqlcmd.ExecuteReader();

Console.WriteLine("列數:" + sr.FieldCount);   
        
Console.WriteLine("列類型分别為:"); 
int nSqlCol = sr.FieldCount;
for (int i = 0; i < nSqlCol; ++i)
Console.Write(sr.GetFieldType(i) + " ");
Console.WriteLine();

while (sr.Read())
{
for (int i = 0; i < nSqlCol; i++)
Console.Write(sr[i].ToString() + " ");
Console.WriteLine();
}
sr.Close();

//通過SqlCommand 類的ExecuteNonQuery()來傳回受影響的行數。
string SQLCOMMAND2 = "update dbo.Messages set MessageNum='15' where MessageID='2'";
SqlCommand sqlcmd2 = new SqlCommand(SQLCOMMAND2, conn);//也可以用sqlcmd. ConnectionString = SQLCOMMAND2 代替
int nResult = sqlcmd2.ExecuteNonQuery();
Console.WriteLine("受影響行數:" + nResult);

conn.Close();
           

在VC++中,可以使用ADO方式通路資料庫,請參閱《VC++ ADO方式通路資料庫簡要筆記》

轉載請标明出處,原文位址:http://blog.csdn.net/morewindows/article/details/6858216