ADO.Net連接SQL Server

要與SQL Server連接,必須將SQL Server安裝在系統中。現在使用Microsoft SQL Server管理工具來連接SQL Server。可以使用這個工具來處理數據庫。現在,按照以下步驟連接SQL Server。

第1步:打開Microsoft SQL Server管理工具,它會提示進行數據庫連接,提供服務器名稱和身份驗證。如下所示 -

ADO.Net連接SQL

連接成功後,顯示如下窗口。如下所示 -

ADO.Net連接SQL

第2步:創建數據庫

現在,通過選擇數據庫選項創建數據庫,然後右鍵單擊它。 它彈出一個選項菜單,並提供了幾個選項。

ADO.Net連接SQL

點擊新建數據庫,然後它要求填寫要創建數據庫名稱。 在這裏,我們創建了一個名稱爲:student 的數據庫。如下圖所示 -

ADO.Net連接SQL

點擊*確定(Ok)*按鈕,它會創建一個數據庫,可以在下面的截圖中的左側窗口看到如下所示。

ADO.Net連接SQL

第3步:建立連接並創建一個表

現在創建數據庫之後,使用下面的C#代碼創建一個表。在這個源代碼中,使用創建的學生數據庫進行連接。

在Visual Studio 2017中,我們創建了一個包含以下C#代碼的.NET控制檯應用程序項目(名稱:AdoNetConsoleApplication) -

ADO.Net連接SQL

參考以下實現代碼(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 執行此代碼。執行完成後,它將顯示一條消息給控制檯,如下所示 -

ADO.Net連接SQL

也可以在Microsoft SQL Server Management Studio中看到創建的表。如下所示所示創建成功的表:student_info
ADO.Net連接SQL

可以看到,在這裏有一張表: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 執行此代碼。 執行完成後,它將顯示一條消息給控制檯,如下所示 -

ADO.Net連接SQL

第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 執行此代碼,它將產生以下結果。這顯示兩條記錄,一條是手動插入的數據記錄。輸出結果如下圖所示:

ADO.Net連接SQL

第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的記錄信息)。

ADO.Net連接SQL