操作sqlserver資料庫常用的三個方法

youou發表於2021-09-09

 1、 ADO.NET

   -> 連線字串,常用的兩種方式:

      server=計算機名或ip例項名;database=資料庫名;uid=sa;pwd=密碼;

      server=計算機名或ip例項名;database=資料庫名;integrated security=true;

   -> 常用的類庫

      SqlConnection 連線資料庫用

      SqlCommand      執行SQL語句

      SqlDataReader 讀取的物件(此種讀取資料的方式有點像StreamReader)

      SqlAdapter    將資料庫中的資料放入DataSet

      DataSet       記憶體級別的離線資料庫(有點像FileStream.Read)

對比模型

圖片描述圖片描述

(圖片來自網路,若是原文作者看到,請提供連結地址,時間很久遠了.......)

   -> 連線資料庫的步驟

      -> 寫連線字串

      -> 建立連線物件,使用連線字串

      -> Open,開啟資料庫

      -> 關閉釋放資料庫,可以使用using

2、執行SQL語句

   -> 使用SqlCommand物件

   -> 步驟:

      -> 首先建立SQL語句字串(sql)與連線通道SqlConnection(conn)    

1 string sql = "insert into tbl(id, name) values(1, '123');"
2 SqlConnection conn = new SqlConnection(@"server=計算機名或ip例項名;database=資料庫名;uid=sa;pwd=密碼;");

    -> 建立SqlCommand物件,將sql與conn交給它(透過建構函式或屬性)

 SqlCommand cmd = new SqlCommand(sql, conn);

    -> 在Open的情況下,呼叫方法(SqlCommand物件的方法)      

1 conn.Open();
2  cmd.方法();

  -> 常用的三個方法   

1 ExecuteNonQuery()   專門執行非查詢語句(增、刪、改等),返回受影響行數2 ExecuteScalar()     執行查詢,返回的是結果中第一行第一列的資料(object)  
3 ExecuteReader()     專門執行查詢,可以獲得多行多列的資料

3、 先建立一個表,插入資料

注意問題

      -> sql語句如果在SSMS中執行沒有問題在ADO.Net一般不會出現問題

      -> 關於主鍵和自動增長

      -> 連線字串資料庫的名字

      -> 關於約束

   異常處理

圖片描述

 1 try 
 2  { 
 3         // 可能出現異常的程式碼 
 4  } 
 5  
 6  catch(Exception ex) 
 7  
 8  { 
 9         // 出現異常之後的程式碼
 10  }
 11 
 12  finally
 13   {
 14         // 用來關閉連線
 15  }

圖片描述

4、 ExecuteScalar()

     -> 讀取資料,獲取第一行與第一列

     -> 執行中除了SQL語句和執行方法不同流程都一樣

5、-> 將SQL語句中的引數拼接修改一下

   -> 凡是要用到引數的地方,都將這個變數,寫成一個變數

   -> 使用的時候為這個變數賦值即可

   -> 實現步驟

      -> 寫SQL語句的時候,用"@別名"代替挖坑的地方

1  select COUNT(*) from tblLogin where logUid='{0}' and logPwd='{1}';容易sql注入漏洞攻擊
2  select COUNT(*) from tblLogin where logUid=@logUid and logPwd=@logPwd;

  -> 在ADO.Net中執行SQL語句前(cmd.方法()呼叫前)

      -> 建立一個物件,SqlParameter

1 SqlParameter p = new SqlParameter(引數的別名, 引數的值);
2 SqlParameter p1 = new SqlParameter("@logUid", txtUid.Text.Trim());
3 SqlParameter p2 = new SqlParameter("@logPwd", txtPwd.Text);

    -> 將引數加到cmd物件中        

cmd.Parameters.Add(引數物件);cmd.Parameters.Add(p1);

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4729/viewspace-2808543/,如需轉載,請註明出處,否則將追究法律責任。

相關文章