相關知識:
代碼示例:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using System.Data; 7 using System.Data.SqlClient; 8 9 namespace Consoleapplication1310 {11 class PRogram12 {13 static string strConn = @"server=Joe-PC;database=AccountDBforSQLInjection;uid=sa;pwd=root";14 static SqlConnection conn = new SqlConnection(strConn);15 16 static string sql1 = "INSERT INTO Account(AccountID,AccountName,passWord) VALUES"17 + "(100,'sql1','123456')";//此命令正確18 static string sql2 = "INSERT INTO Account(AccountID,AccountName1,password) VALUES"19 + "(100,'sql2','123456')";//此命令因有拼寫錯誤將會失敗20 21 static SqlCommand cmd1 = new SqlCommand(sql1, conn);22 static SqlCommand cmd2 = new SqlCommand(sql2, conn);23 24 static void Main(string[] args)25 {26 //OperationWithoutTransaction();27 OperationWithTransaction();28 }29 30 static void OperationWithoutTransaction()31 {32 conn.Open();33 34 try35 {36 cmd1.ExecuteNonQuery();37 cmd2.ExecuteNonQuery();38 }39 catch (Exception e)40 {41 Console.WriteLine("執行失敗。");42 Console.WriteLine(e);43 }44 finally45 {46 conn.Close();47 }48 }49 50 static void OperationWithTransaction()51 {52 conn.Open();53 //連接打開后,才能啟動事務54 SqlTransaction trans = conn.BeginTransaction();55 //將兩個操作添加到同一個事務中56 cmd1.Transaction = trans;57 cmd2.Transaction = trans;58 59 try60 {61 cmd1.ExecuteNonQuery();62 cmd2.ExecuteNonQuery();63 //如果沒有出現異常,則提交事務64 trans.Commit();65 }66 catch (Exception e)67 {68 Console.WriteLine("執行失敗,事務回滾。");69 Console.WriteLine(e);70 //執行回滾71 trans.Rollback();72 }73 finally74 {75 conn.Close();76 }77 }78 }79 }
程序分析:
新聞熱點
疑難解答
圖片精選