亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#連接SQL Server數(shù)據(jù)庫的實(shí)例講解

 更新時(shí)間:2020年01月31日 14:52:53   作者:人生、蛻變  
在本篇文章里小編給大家整理了關(guān)于C#連接SQL Server數(shù)據(jù)庫的實(shí)例內(nèi)容,有需要的朋友們參考學(xué)習(xí)下。

C#連接數(shù)據(jù)庫:Connection對象

1.Connection對象概述

Connection對象是一個(gè)連接對象,主要功能是建立與物理數(shù)據(jù)庫的連接。其主要包括4種訪問數(shù)據(jù)庫的對象類,也可稱為數(shù)據(jù)提供程序,分別介紹如下。

  • SQL Server數(shù)據(jù)提供程序,位于System.Data.SqlClient命名空間。
  • ODBC數(shù)據(jù)提供程序,位于System.Data.Odbc命名空間。
  • OLEDB數(shù)據(jù)提供程序,位于System.Data.OleDb命名空間。
  • Oracle數(shù)據(jù)提供程序,位于System.Data.OracleClient命名空間。

說明:根據(jù)使用數(shù)據(jù)庫的不同,引入不同的命名空間,然后通過命名空間中的Connection對象連接類連接數(shù)據(jù)庫。例如,連接SQL Server數(shù)據(jù)庫,首先要通過using System.Data.SqlClient命令引用SQL Server數(shù)據(jù)提供程序,然后才能調(diào)用空間下的SqlConnection類連接數(shù)據(jù)庫。

2.連接數(shù)據(jù)庫

以SQL Server數(shù)據(jù)庫為例,如果要連接SQL Server數(shù)據(jù)庫,必須使用System.Data.SqlClient命名空間下的SqlConnection類。所以首先要通過using System.Data.SqlClient命令引用命名空間,連接數(shù)據(jù)庫之后,通過調(diào)用SqlConnection對象的Open方法打開數(shù)據(jù)庫。通過SqlConnection對象的State屬性判斷數(shù)據(jù)庫的連接狀態(tài)。

界面:

代碼:

private void btn1_Click(object sender, EventArgs e)
    {
      if (txt1.Text == "")
      {
        MessageBox.Show("請輸入要連接的數(shù)據(jù)庫名稱!");
      }
      else
      {
        try
        {
          string connString = "server=.;database=" + txt1.Text.Trim() + ";uid=test;pwd=test;connect timeout=5"; //**
          SqlConnection sqlConnection = new SqlConnection(connString); //**
          sqlConnection.Open(); //**

          if (sqlConnection.State == ConnectionState.Open)
          {
            lab2.Text = "數(shù)據(jù)庫【" + txt1.Text.Trim() + "】已經(jīng)連接并打開!";
          }
        }
        catch
        {
          MessageBox.Show("數(shù)據(jù)庫連接失敗!");
        }
      }
    }

3.關(guān)閉連接

當(dāng)對數(shù)據(jù)庫操作完畢后,要關(guān)閉與數(shù)據(jù)庫的連接,釋放占用的資源??梢酝ㄟ^調(diào)用SqlConnection對象的Close方法或Dispose方法關(guān)閉與數(shù)據(jù)庫的連接。這兩種方法的主要區(qū)別是:Close方法用于關(guān)閉一個(gè)連接,而Dispose方法不僅關(guān)閉一個(gè)連接,而且還清理連接所占用的資源。當(dāng)使用Close方法關(guān)閉連接后,可以再調(diào)用Open方法打開連接,不會產(chǎn)生任何錯(cuò)誤。而如果使用Dispose方法關(guān)閉連接,就不可以直接用Open方法打開連接,必須再次重新初始化連接再打開。

界面:

 

代碼:

SqlConnection sqlConnection; //***
    /// <summary>
    /// 連接數(shù)據(jù)庫
    /// </summary>
    private void btn1_Click_1(object sender, EventArgs e)
    {
      if (txt1.Text == "")
      {
        MessageBox.Show("請輸入數(shù)據(jù)庫名稱:");
      }
      else
      {
        try
        {
          string connString = "server=.;database=" + txt1.Text.Trim() + ";uid=test;pwd=test;connect timeout=5"; //***
          sqlConnection = new SqlConnection(connString); //***
          sqlConnection.Open(); //***

          if (sqlConnection.State == ConnectionState.Open)
          {
            btn1.Text = "連接成功";
          }
        }
        catch(Exception ex) 
        {
          MessageBox.Show(ex.Message);
          txt1.Text = "";
        }
      }
    }

    /// <summary>
    /// 使用Close方法關(guān)閉連接并重新調(diào)用Open方法連接數(shù)據(jù)庫
    /// </summary>
    private void btn2_Click(object sender, EventArgs e)
    {
      try
      {
        string str = "";

        sqlConnection.Close(); //***
        if (sqlConnection.State == ConnectionState.Closed)
        {
          str = "數(shù)據(jù)庫已經(jīng)成功關(guān)閉\n";
        }

        sqlConnection.Open(); //***
        if (sqlConnection.State == ConnectionState.Open)
        {
          str += "數(shù)據(jù)庫已經(jīng)成功打開\n";
        }

        rtbox1.Text = str;
      }
      catch (Exception ex)
      {
        rtbox1.Text = ex.Message;
      }
    }

    /// <summary>
    /// 使用Dispose方法關(guān)閉連接并重新調(diào)用Open方法連接數(shù)據(jù)庫
    /// </summary>
    private void btn3_Click(object sender, EventArgs e)
    {
      try
      {
        sqlConnection.Dispose(); //***
        sqlConnection.Open(); //***
      }
      catch (Exception ex)
      {
        rtbox1.Text = ex.Message;
      }
    }

以上就是本次介紹的全部知識點(diǎn)內(nèi)容,感謝大家的學(xué)習(xí)和對腳本之家的支持。

相關(guān)文章

  • Winform使用FTP實(shí)現(xiàn)自動更新

    Winform使用FTP實(shí)現(xiàn)自動更新

    這篇文章主要為大家詳細(xì)介紹了Winform使用FTP實(shí)現(xiàn)自動更新,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • C#隨機(jī)數(shù)生成字母金字塔

    C#隨機(jī)數(shù)生成字母金字塔

    這篇文章主要為大家詳細(xì)介紹了C#隨機(jī)數(shù)生成字母金字塔,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • C#實(shí)現(xiàn)查殺本地與遠(yuǎn)程進(jìn)程的方法

    C#實(shí)現(xiàn)查殺本地與遠(yuǎn)程進(jìn)程的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)查殺本地與遠(yuǎn)程進(jìn)程的方法,可實(shí)現(xiàn)針對特定進(jìn)程的關(guān)閉操作,是C#進(jìn)程操作的一個(gè)典型應(yīng)用,需要的朋友可以參考下
    2014-12-12
  • WPF中的導(dǎo)航框架概述

    WPF中的導(dǎo)航框架概述

    這篇文章介紹了WPF中的導(dǎo)航框架,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • c# List find()方法返回值的問題說明(返回結(jié)果為對象的指針)

    c# List find()方法返回值的問題說明(返回結(jié)果為對象的指針)

    本篇文章主要介紹了c#中List find()方法返回值的問題說明(返回結(jié)果為對象的指針) 需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • 深入解析c#中枚舉類型的定義與使用

    深入解析c#中枚舉類型的定義與使用

    以下是對c#中枚舉類型的定義與使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下
    2013-08-08
  • unity 如何獲取Text組件里text內(nèi)容的長度

    unity 如何獲取Text組件里text內(nèi)容的長度

    這篇文章主要介紹了unity 獲取Text組件里text內(nèi)容的長度操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • c#高效比對大量圖片的實(shí)例代碼

    c#高效比對大量圖片的實(shí)例代碼

    以前傳統(tǒng)的比較方式是遍歷圖片中的每一個(gè)像素,然后進(jìn)行比對。這樣的比對在少量圖片的比對上雖然效率低一點(diǎn),但是也沒有什么不好。但是在大量圖片比對的時(shí)候,過長的反應(yīng)時(shí)間和對服務(wù)器比較高的消耗肯定是不行的,下面介紹下新的方法
    2013-10-10
  • Winform窗體圓角設(shè)計(jì)代碼

    Winform窗體圓角設(shè)計(jì)代碼

    這篇文章主要為大家詳細(xì)介紹了Winform窗體圓角設(shè)計(jì)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • C# winfroms使用socket客戶端服務(wù)端的示例代碼

    C# winfroms使用socket客戶端服務(wù)端的示例代碼

    這篇文章主要為大家詳細(xì)介紹了C# winfroms使用socket客戶端服務(wù)端的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02

最新評論