3

首先,我对编程很陌生,所以对细节的关注是值得赞赏的。

我目前有一个从 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 的复选框列表中仅删除选定的项目?

4

1 回答 1

1

当您说商品“完全相同”时,您的意思是它们具有相同的商品代码吗?并且项目代码允许在您的系统中重复(即,这是正确的业务规则)?

如果是这样,这就是为什么您需要为每一行自动生成一个 ID,以便每一行都是唯一的。这意味着您需要在DELETE查询中使用该 ID 而不是商品代码。

通常,在(ASP.NET)Web 应用程序中,这类事情是通过“网格”完成的。您可以将 aGridView与两列一起使用:一列是复选框,另一列只是显示项目代码的标签。每行都绑定到 ID 字段。

因此,我建议您首先查看GridView(网上有很多示例):GridView 的 MSDN 文档

于 2013-04-30T20:18:17.753 回答