我在執行循環內過程時遇到問題。我的要求是將數據插入表中。第一列是我試圖進入循環的字母表,接下來的三列對於所有行都是常見的。但是在第一次迭代之後,我發現錯誤必須是唯一的。錯誤在循環中執行過程
string str = Properties.Settings.Default.con;
SqlConnection con = new SqlConnection(str);
char[] az = Enumerable.Range('A', 'Z' - 'A' + 1).Select(i => (Char)i).ToArray();
SqlCommand cmd = new SqlCommand("Execute InsertPurchase @ShipTo,@StoreName,@desc,@Alpha", con);
try
{
cmd.Parameters.AddWithValue("@ShipTo", txtstoreto.Text);
cmd.Parameters.AddWithValue("@StoreName", txtstorefrom.Text);
cmd.Parameters.AddWithValue("@desc", Globals.s_desc.ToString());
con.Open();
foreach (var c in az)
{
cmd.Parameters.AddWithValue("@Alpha", c.ToString());
cmd.ExecuteNonQuery();
}
con.Close();
j = true;
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
錯誤消息:
變量名 '@Alpha' 已聲明。變量名稱在查詢批處理或存儲過程中必須是唯一的。
那是因爲你的'foreach'的。 Foreach在z中添加新參數。在將其添加爲參數之前,先構建您的C字符串。 –