Привязка данных к программно созданному DataTable - PullRequest
0 голосов
/ 08 января 2009

Предположим, у меня есть такой тип данных:

        DataTable dt = new DataTable("Woot");

        dt.Columns.AddRange(new DataColumn[]{
            new DataColumn("ID",typeof(System.Guid)),
            new DataColumn("Name",typeof(String))
            });

Когда я пытаюсь привязать к нему элемент управления:

        this.txtName.DataBindings.Add("Text", _dtRow, "Name");

Я получаю это исключение:

Невозможно привязать к свойству или столбцу Имя в источнике данных. параметр имя: dataMember

Есть идеи, почему это работает с таблицей данных, созданной dataAdapter, но не с программно созданным?

Ответы [ 2 ]

3 голосов
/ 08 января 2009

Ладно, после того, как я немного поигрался с твоим кодом, я продолжал тупить. Тогда я наконец понял проблему. Я предполагаю, что _dtRow является DataRow. Вам необходимо сослаться на фактическую таблицу данных (dt).

this.textBox1.DataBindings.Add("Text", dt, "Name");

РЕДАКТИРОВАТЬ: После просмотра вашего комментария на пост Игоря. Если вы связываетесь с dt, то, например, скажите, если у вас есть таблица данных, привязанная к этой таблице данных, каждый раз, когда вы выбираете другую строку, текстовое поле будет меняться.

Вот код, который работает для меня:

            DataTable dt = new DataTable("Woot");

            dt.Columns.AddRange(new DataColumn[]{
            new DataColumn("ID",typeof(System.Guid)),
            new DataColumn("Name",typeof(String))
            });


            dt.Rows.Add(Guid.NewGuid(), "John");
            dt.Rows.Add(Guid.NewGuid(), "Jack");

            this.dataGridView1.DataSource = dt;

            this.textBox1.DataBindings.Add("Text", dt, "Name");

Измените строки в DGV, и вы увидите текст изменения текстового поля.

СНОВА EIDT Хорошо, время взломать его. Вот как я заставил его работать:

this.textBox1.DataBindings.Add("Text",_dtRow.ItemArray[1], ""); 

Я использовал индекс 1, но вы можете использовать любой нужный вам индекс в массиве.

1 голос
/ 08 января 2009

разве вы не должны ссылаться на dt вместо _dtRow?

Например:

this.txtName.DataBindings.Add("Text", dt, "Name");

EDIT:

Этот код работал для меня:

   DataTable dt = new DataTable("Woot");

    dt.Columns.AddRange(new DataColumn[]{
        new DataColumn("ID",typeof(System.Guid)),
        new DataColumn("Name",typeof(String))
    });

    DataRow r = dt.NewRow();
    r["ID"] = new Guid();
    r["Name"] = "AAA";
    dt.Rows.Add(r);

    r = dt.NewRow();
    r["ID"] = new Guid();
    r["Name"] = "BBB";
    dt.Rows.Add(r);

    dataGridView1.DataSource = dt;

    this.txtName.DataBindings.Add("Text", r.Table , "Name");
...