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で質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Access(アクセス) Accessの参照フィールドの列がずれてしまいます 1 2023/07/19 15:00
- SQL Server DBのテーブルの設計ができず困っています。 2 2023/06/29 16:43
- Access(アクセス) Accessにインポートした複数のテーブルを表示させる方法が分かりません。 1 2023/01/30 20:22
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- Excel(エクセル) Excel ドロップダウンリスト(入力規則)に関してです データの入力規則で元データ79000行のド 3 2023/07/17 10:06
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- Visual Basic(VBA) ユーザーフォームの書き出しで追加のご相談 ユーザーフォームの値をシートに書き出す際、コードが表示され 2 2022/08/05 10:58
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
『列名 '担当者CD' があいま...
-
VBとアクセスでSQL文に変...
-
Accessで別mdbのテーブルをコピー
-
手動または分散トランザクショ...
-
.net 複数の主キーを設定する方法
-
DataGridViewで変更した値を反...
-
エクセルのテーブルを解除する...
-
AccessからExcelへエクスポート...
-
種類別のテーブル作成方法について
-
C# OleDbDataAdapter.Fillメソ...
-
【ADO】「Execute」を使うと...
-
ワークテーブルの作成について
-
Access2003VBA リンクテーブル...
-
VB2008・DataGridの表示について
-
同一セッションIDのブラウザを...
-
AccessVBAコミットとロールバッ...
-
★クリスタルレポートの元になる...
-
(泣)VBscriptでinnerhtmlを使...
-
CSVファイルのエクスポートでソ...
-
他のMDBのテーブルに追加したい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBとアクセスでSQL文に変...
-
WORD VBA プログラム修正をお願...
-
Accessで別mdbのテーブルをコピー
-
『列名 '担当者CD' があいま...
-
DataGridViewに複数テーブルの...
-
他のMDBのテーブルに追加したい
-
エクセルのテーブルを解除する...
-
Excel複数シートをaccessへ一括...
-
手動または分散トランザクショ...
-
SQLを発行とは?クエリの作成と...
-
AccessからExcelへエクスポート...
-
CSVファイルのエクスポートでソ...
-
ACCESS2010 実行時エラー 2766
-
HTMLのテーブルの行数が多くな...
-
ExcelVBAからAccessMDB内のテー...
-
【ADO】「Execute」を使うと...
-
★クリスタルレポートの元になる...
-
DataGridの中身をDataSetにテー...
-
ACCESSのテーブル名をリストに...
-
COBOLのINVALID KEYが理解でき...
おすすめ情報