ADO.Net連接SQL Server
要與SQL Server連接,必須將SQL Server安裝在系統中。現在使用Microsoft SQL Server管理工具來連接SQL Server。可以使用這個工具來處理數據庫。現在,按照以下步驟連接SQL Server。
第1步:打開Microsoft SQL Server管理工具,它會提示進行數據庫連接,提供服務器名稱和身份驗證。如下所示 -
連接成功後,顯示如下窗口。如下所示 -
第2步:創建數據庫
現在,通過選擇數據庫選項創建數據庫,然後右鍵單擊它。 它彈出一個選項菜單,並提供了幾個選項。
點擊新建數據庫,然後它要求填寫要創建數據庫名稱。 在這裏,我們創建了一個名稱爲:student 的數據庫。如下圖所示 -
點擊*確定(Ok)*按鈕,它會創建一個數據庫,可以在下面的截圖中的左側窗口看到如下所示。
第3步:建立連接並創建一個表
現在創建數據庫之後,使用下面的C#
代碼創建一個表。在這個源代碼中,使用創建的學生數據庫進行連接。
在Visual Studio 2017中,我們創建了一個包含以下C#
代碼的.NET控制檯應用程序項目(名稱:AdoNetConsoleApplication) -
參考以下實現代碼(Programe.cs) -
using System;
using System.Data.SqlClient;
namespace Programe
{
class Program
{
static void Main(string[] args)
{
new Program().CreateTable();
}
public void CreateTable()
{
SqlConnection con = null;
try
{
// Creating Connection
con = new SqlConnection("data source=.; database=student; integrated security=SSPI");
// writing sql query
SqlCommand cm = new SqlCommand("create table student_info(id int not null,name varchar(100), email varchar(50), join_date date)", con);
// Opening Connection
con.Open();
// Executing the SQL query
cm.ExecuteNonQuery();
// Displaying a message
Console.WriteLine("Table created Successfully");
}
catch (Exception e)
{
Console.WriteLine("OOPs, something went wrong." + e);
}
// Closing the connection
finally
{
con.Close();
}
}
}
}
使用Ctrl + F5 執行此代碼。執行完成後,它將顯示一條消息給控制檯,如下所示 -
也可以在Microsoft SQL Server Management Studio中看到創建的表。如下所示所示創建成功的表:student_info。
可以看到,在這裏有一張表:student_info。但此時,這張表是空的,所以需要插入一些數據。
第4步: 將數據插入到表中,參考以下實現代碼(AdoNetInsert.cs) -
using System;
using System.Data.SqlClient;
namespace AdoNetConsoleApplication
{
class AdoNetInsert
{
static void Main(string[] args)
{
new AdoNetInsert().InsertTable();
}
public void InsertTable()
{
SqlConnection con = null;
try
{
// Creating Connection
con = new SqlConnection("data source=.; database=student; integrated security=SSPI");
// writing sql query
String sql = "insert into student_info(id, name, email, join_date)values('101', 'Hiniu Su', '[email protected]', '2017-11-18')";
SqlCommand cm = new SqlCommand(sql, con);
// Opening Connection
con.Open();
// Executing the SQL query
cm.ExecuteNonQuery();
// Displaying a message
Console.WriteLine("插入數據記錄成功~!");
}
catch (Exception e)
{
Console.WriteLine("OOPs, something went wrong." + e);
}
// Closing the connection
finally
{
con.Close();
}
}
}
}
使用Ctrl + F5 執行此代碼。 執行完成後,它將顯示一條消息給控制檯,如下所示 -
第5步:查詢/檢索記錄
在這裏,將查詢/檢索上一步中插入的數據。參考下面的C#
實現代碼(AdoNetSelect.cs)-
using System;
using System.Data.SqlClient;
namespace AdoNetConsoleApplication
{
class AdoNetSelect
{
static void Main(string[] args)
{
new AdoNetSelect().SelectTable();
}
public void SelectTable()
{
SqlConnection con = null;
try
{
// Creating Connection
con = new SqlConnection("data source=.; database=student; integrated security=SSPI");
// writing sql query
SqlCommand cm = new SqlCommand("SELECT * FROM student_info", con);
// Opening Connection
con.Open();
// Executing the SQL query
SqlDataReader sdr = cm.ExecuteReader();
Console.WriteLine("當前 student_info 表中的記錄爲:" );
// Iterating Data
while (sdr.Read())
{
Console.WriteLine(sdr["id"] + " " + sdr["name"] + " " + sdr["email"]); // Displaying Record
}
}
catch (Exception e)
{
Console.WriteLine("OOPs, something went wrong.\n" + e);
}
// Closing the connection
finally
{
con.Close();
}
}
}
}
通過Ctrl + F5 執行此代碼,它將產生以下結果。這顯示兩條記錄,一條是手動插入的數據記錄。輸出結果如下圖所示:
第6步: 刪除記錄
經過前面5步,現在student_info表中有兩個記錄。以下C#
代碼從表中刪除一行。參考代碼 (AdoNetDelete.cs)-
using System;
using System.Collections.Generic;
using System;
using System.Data.SqlClient;
namespace AdoNetConsoleApplication
{
class AdoNetDelete
{
static void Main(string[] args)
{
new AdoNetDelete().DeleteFromTable();
}
public void DeleteFromTable()
{
SqlConnection con = null;
try
{
// Creating Connection
con = new SqlConnection("data source=.; database=student; integrated security=SSPI");
// writing sql query
SqlCommand cm = new SqlCommand("delete from student_info where id = '101'", con);
// Opening Connection
con.Open();
// Executing the SQL query
cm.ExecuteNonQuery();
Console.WriteLine("已經成功地刪除了編號爲:101 的學生數據信息~!");
// 重新查詢數據庫中的記錄信息
SqlCommand cm2 = new SqlCommand("SELECT * FROM student_info", con);
// Executing the SQL query
SqlDataReader sdr = cm2.ExecuteReader();
Console.WriteLine("當前 student_info 表中的記錄爲:");
// Iterating Data
while (sdr.Read())
{
Console.WriteLine(sdr["id"] + " " + sdr["name"] + " " + sdr["email"]); // Displaying Record
}
}
catch (Exception e)
{
Console.WriteLine("OOPs, something went wrong.\n" + e);
}
// Closing the connection
finally
{
con.Close();
}
}
}
}
通過Ctrl + F5 執行此代碼,它將產生以下結果(ID是111
的這一條已經被刪除了,這裏只顯示編號爲102
的記錄信息)。