0 GP
.Net中SqlCommand.Parameters必須要給予值
作者:怪鳥│2010-10-21 12:55:30│巴幣:0│人氣:546
雖然從.net framework 3.5開始,微軟就推薦使用Linq讀取SQL Server資料,但是我還是喜歡傳統做法。今天這讓我嘗到苦果。
請看以下範例使用C#
SqlConnection conn = new SqlConnection(ConnectionString);
SqlCommand InsCmd
= new SqlCommand("INSERT INTO [TableName]([COLA],[COLB])VALUES(@COLA,@COLB)", conn);
InsCmd.Parameters.Add("@COLA", SqlDbType.NVarChar, 5).Value="aa";
InsCmd.Parameters.Add("@COLB", SqlDbType.NVarChar, 5);
conn .Open();
InsCmd.ExecuteNonQuery();
conn .Close();
以上範例編譯時沒問題,執行了也不會出錯,但是資料就是沒寫進資料庫。仔細檢查才發現@COLB忘記值了。如果編譯時檢查不出也就算了,為何執行時也不丟出exception?微軟,我真是猜不透你阿。
雖然Linq能在編譯時就知道SQL command的錯誤,但是這世界又不是只有SQL Server。所以我決定還是繼續堅守傳統的SQL command。
引用網址:https://home.gamer.com.tw/TrackBack.php?sn=546026
All rights reserved. 版權所有,保留一切權利