首先,我对编程很陌生,所以对细节的关注是值得赞赏的。
我目前有一个从 SQL 表接收数据的 asp 复选框列表。我遇到了一个问题,如果有 2 个项目完全相同,我的删除功能将删除这两个项目。以下是代码:
protected void btn_remove_Click(object sender, EventArgs e)
{
for (int i = 0; i < UPCList.Items.Count; i++)
{
if (UPCList.Items[i].Selected)
{
var item = UPCList.Items[i];
var frcID = item.Value;
_itemNumberRepository.Delete(frcID);
}
}
Response.Redirect("WebForm2.aspx");
Response.End();
}
public string Delete(string itemCode)
{
string connectionString = foobar
Int32 returnDeleted = 0;
string deleteUpcCode =
"DELETE FROM compare1 "
+ string.Format("WHERE itemcode = '{0}'",itemCode);
using (SqlConnection connection = new SqlConnection(connectionString))
{
SqlCommand command = new SqlCommand(deleteUpcCode, connection);
command.Connection.Open();
returnDeleted = command.ExecuteNonQuery();
command.Connection.Close();
}
return returnDeleted.ToString();
}
我被告知要使用 SQL 中的 Auto Incrementing ID,以便每一行都有一个唯一的 ID,因此我只能删除选定的行。但是,我什至不知道如何做到这一点。我已经在 SQL 中为 itemcode 列打开了标识选项,但除此之外,我迷路了。如何使用该 ID 从 asp 的复选框列表中仅删除选定的项目?