
DataGridViewへのコンボボックス利用で躓いております。
DataGridViewのAutoGenerateColumnsをfalseにし、dataGridView.DataSourceにデータベースから読み込んだデータテーブルを指定しています。
次にdataGridViewにDataGridViewComboBoxColumnを追加し、DataPropertyNameにコンボボックスに対応させたい
データテーブルのCaptionを指定することで、データテーブルとコンボボックスを関連付けています。
実行後の表示は想定通りなのですが、コンボボックスでアイテムを選択するとdataGridView上では値が更新されて、データテーブルには変更が反映されていません。
ちなみにコンボボックスでは、ValueMemberとDisplayMemberを設定し、DataGridView上ではstring、
内部的にはlongでデータ管理を行いたいと思っています。
どうにも解決方法が見いだせないので、こちらに質問させていただきました。
ソースを貼りつけるのでご指摘をお願いします。
利用しているデータベース
|ID|ペットID|
|1 |1|
|2 |1|
|3 |3|
以下ソースでは上記データベースのデータテーブルをpdtとしています。
コンボボックスのデータテーブル作成
DataTable comboTable = new DataTable();
comboTable.Columns.Add("ID", typeof(long));
comboTable.Columns.Add("NAME", typeof(string));
string[,] rowDataArray =
{{"1", "犬"},
{"2", "猫"},
{"3", "魚"}};
for(i=0;i<rowDataArray.GetLength(0);i++)
{
DataRow row = comboTable.NewRow();
row["ID"] = rowDataArray[i, 0];
row["NAME"] = rowDataArray[i, 1];
comboTable.Rows.Add(row);
}
comboTable.AcceptChanges();
//コンボボックスを作成しコンボボックステーブルをバインド
DataGridViewComboBoxColumn cbc = new DataGridViewComboBoxColumn();
cbc.DataSource = comboTable;
cbc.DisplayMember = "NAME";
cbc.ValueMember = "ID";
cbc.DataPropertyName = pdt.ペットIDColumn.Caption;
cbc.DisplayStyleForCurrentCellOnly = true;
//dataGridViewにデータテーブルをバインド
dataGridView1.AutoGenerateColumns = false;
dataGridView1.DataSource = pdt;
dataGridView1.Columns.Add(cbc);
これを実行すると
|犬|
|犬|
|魚|
とdataGridViewに表示され、コンボボックスでは、犬、猫、魚が選べます。
一行目において、コンボボックスから猫を選択するとdataGridViewは下記のようになるのですが
|猫|
|犬|
|魚|
この後ブレークよりデータテーブルとdataGridViewを見ると
pdt[0][0] = 1
dataGridView1.Rows[0].Cells[0].Value = 2
となっており、dataGridViewの値は更新されているのに、データテーブルでは更新されていませんでした。
今まで、dataGridView上でダブルクリックし、値を直接書き換えていたらデータテーブルの値も更新されていたのですが、
コンボボックスを使うようにしたら更新されなくなりました。
皆様、解決方法を教えていただけますでしょうか。
No.1ベストアンサー
- 回答日時:
comboTable.Columns.Add("ID");
comboTable.Columns.Add("NAME");
としてみるとどうですか?
どのタイミングで確認しているのかわかりませんが、画面上にもう一つDataGridViewを追加して、DataSourceにpdtをただ設定してみれば、どのようにpdtの値が変わっているか確認できます。
No.1様。回答ありがとうございました。
No1様のおかげで解決しました。
原因は私のミスでした。
DataGridViewを追加して見てみたところ、コンボボックスで値を変更した後、フォーカスを他のセルに写したときデータテーブルの値が変更されていたので、再度確認したところ無事コンボボックスの値がデータテーブルに反映されました。ソースを多少いじっているので原因はわかりませんが、再度同じ方法でやり直したらうまくいったので、私のデバッグ方法が悪かったのだと思います。早とちりで皆様にご迷惑をおかけしてしまい申し訳ありませんでした。
また、comboTable.Columns.Add("NAME");で型を指定しない場合、コンボボックスの値をstringで与えているためエラー表示されました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
データバインドされたDatagridviewの列をコンボボックスにするには
Visual Basic(VBA)
-
DataGridViewのチェックボックスのON、OFFの判定方法
C言語・C++・C#
-
DataGridViewでyyyy/MM/dd
Visual Basic(VBA)
-
-
4
データグリッドビューの一番最初の行に列を追加したい
Visual Basic(VBA)
-
5
DataGridViewの特定列に入力されている重複チェックをしたい
Visual Basic(VBA)
-
6
DataGridViewの、選択されている行を取り出したい
Visual Basic(VBA)
-
7
CellEnterイベント仕様について
Visual Basic(VBA)
-
8
DataGridViewのセルのItem設定につい
C言語・C++・C#
-
9
C# DataGridViewで複数選択したセルに同じ値を一括で入力するには
C言語・C++・C#
-
10
C# DataTableの行をソートしてDataGridViewに反映させたい
C言語・C++・C#
-
11
コンボボックスでドロップダウンリストにしたときに・・・・
Visual Basic(VBA)
-
12
DataGridViewのコンボボックスの初期値について
Visual Basic(VBA)
-
13
VB.NET DataGridView 縦スクロールバーを常に表示
Visual Basic(VBA)
-
14
Visual Studio 「AnyCpu」について
C言語・C++・C#
-
15
C# DataTableに最後に追加した行をDataGridView上で選択状態にする方法は?
C言語・C++・C#
-
16
【VB】タブ切り替え時のイベント
Visual Basic(VBA)
-
17
C# 配列などの受け渡し
その他(プログラミング・Web制作)
-
18
DataTableから条件を満たした行を別のDatatableへコピーしたい
その他(プログラミング・Web制作)
-
19
DataGridViewにてセル以外をクリックしたか判別
Visual Basic(VBA)
-
20
CloseとDisposeの違い
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBとアクセスでSQL文に変...
-
AccessからExcelへエクスポート...
-
COBOLのINVALID KEYが理解でき...
-
SQLを発行とは?クエリの作成と...
-
『列名 '担当者CD' があいま...
-
他のMDBのテーブルに追加したい
-
DataGridViewに複数テーブルの...
-
CSVファイルのエクスポートでソ...
-
Accessで別mdbのテーブルをコピー
-
手動または分散トランザクショ...
-
オラクルデータベースへの更新方法
-
.net 複数の主キーを設定する方法
-
SQLSERVERからデータを取得する...
-
vb ado → vb2005 ado.net変換
-
★クリスタルレポートの元になる...
-
VB6からの移行したいけど、VB.N...
-
2次元のdictionary
-
C# DataTableに最後に追加した...
-
【VB.NET】Excelの最終行までの...
-
vb2008 コントロール配列
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
『列名 '担当者CD' があいま...
-
SQLを発行とは?クエリの作成と...
-
VBとアクセスでSQL文に変...
-
他のMDBのテーブルに追加したい
-
手動または分散トランザクショ...
-
エクセルのテーブルを解除する...
-
COBOLのINVALID KEYが理解でき...
-
AccessからExcelへエクスポート...
-
ExcelVBAからAccessMDB内のテー...
-
CSVファイルのエクスポートでソ...
-
DAOの作成単位について
-
ワークテーブルの作成について
-
Accessで別mdbのテーブルをコピー
-
Access2007でアプリケーション...
-
DataGridViewに複数テーブルの...
-
VB.NETでのAccessテーブルリンク
-
ACCESS2010 実行時エラー 2766
-
Excel複数シートをaccessへ一括...
-
[C#] DataGridViewでコンボボッ...
-
Accessでテーブルのデータのみ...
おすすめ情報