0

我有一个数据中继器,以下代码仅删除第一条记录,无论选择哪条记录。我不完全相信这是使用数据中继器的正确方法,但我找不到更好的解决方案。我需要能够选择任何记录并将其删除。

    //delete document
    private void cmdDeleteDoc_Click(object sender, EventArgs e)
    {

        if (this.dataRepeater1.CurrentItemIndex == 0)
        {

            //begin reset
            this.dataRepeater1.BeginResetItemTemplate();
            // Delete Row Here

            DataClasses1DataContext db = new DataClasses1DataContext();

            System.Data.DataRowView SelectedRowView;
            newCityCollectionDataSet.DocumentsRow SelectedRow;

            SelectedRowView = (System.Data.DataRowView)documentsBindingSource.Current;
            SelectedRow = (newCityCollectionDataSet.DocumentsRow)SelectedRowView.Row;


            var matchedDocument = (from c in db.GetTable<Document>()
                                   where c.DocIDKey == SelectedRow.DocIDKey
                                   select c).SingleOrDefault();

            db.Documents.DeleteOnSubmit(matchedDocument);
            db.SubmitChanges();

            LoadCaseNumberKey(matchedDocument.CaseNumberKey, false, "documents");
            this.dataRepeater1.EndResetItemTemplate();
        }


    }

任何帮助都会很棒!

4

1 回答 1

1

我的猜测是你的混淆了你的documentsBindingSource和你的dataRepeater

您在视觉上“看到”的是 dataRepeater,而您“得到”的是documentsBindingSource.Current(您检索为 being SelectedRowView
,它始终设置为 0 索引。这是一个非常常见的 Winforms 控制陷阱。

于 2011-05-02T16:11:11.577 回答