6

更改 BindingSource 的数据源时出现的错误

“数据绑定找不到适合所有绑定的行 适合所有绑定的行”

        this.RemoveAllBindings(); // My work-around for the meantime

        bdsOrder.DataSource = _ds.Tables["orders"]; // errors here on second time around(first time is blank datatable, second time is when i open existing record, then it errors), dataset comes from Remoting
        bdsOrderDetail.DataSource = _ds.Tables["order_detail"];

        bdsPhoto.DataSource = _ds.Tables["order_photo"];
        bdnPhoto.BindingSource = bdsPhoto;

我的 Helper 扩展方法解决了令人困惑的“数据绑定找不到行...”错误。

namespace MycComponentExtension
{
    public static class Helper
    {
        public static void RemoveAllBindings(this Form form)
        {
            RemoveAllBindings((Control)form);
        }

        private static void RemoveAllBindings(this Control root)
        {
            foreach (Control c in root.Controls)
            {
                if (c.Controls.Count > 0) RemoveAllBindings(c);

                root.DataBindings.Clear();
            }
        }

“DataBinding 找不到行...”错误是什么意思,如果可能的话,我可以消除我的解决方法吗?

4

1 回答 1

3

当不涉及 DataGridView 时,我看到了这个错误,但是我的数据源正在从另一个线程更新(淘气!)并且我的绑定有 FormattingEnabled=false。改变这两个似乎可以解决问题。

于 2012-06-06T04:53:28.140 回答