質問させてください。
環境:PostgreSQL、VB.NET2010、Npgsql
PostgreSQL上のDBには以下のテーブルを準備
create table test_table (
id serial not null primary key,
category_name text not null
);
とりあえず1行のデータのみ入っています。
ユーザフォームにDataGridViewとButtonとBindingSourceを1つづつ配置。
以下のプログラムでフォームロード時にDBの内容をDataGridViewへ表示させることまでできました。
Imports Npgsql
Public Class Form1
Public Const conn = "Server=****;Port=****;User Id=****;Password=****;Database=****;"
Private DA As NpgsqlDataAdapter
Private DT As New DataTable
Private Sub Form1_Load(省略)
Try
Dim command As String = "select * from test_table"
DA = New Npgsql.NpgsqlDataAdapter( command, conn )
DT = New DataTable
DA.Fill(DT)
BindingSource1.DataSource = DT
DataGridView1.DataSource = BindingSource1.DataSource
Catch ex As Exception
MessageBox.Show(ex.Message.ToString(), "エラー")
End Try
End Sub
End Class
そこで、このDataGridViewへユーザが入力、修正し、配置したボタンを押すことでDBへ反映させたいのですが、この部分がよくわからなくて困っています。
PostgreSQL以外のDBはサンプルが沢山あるのですが・・・・
よろしくお願いします。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
>>業務はそれを待ってくれずとりあえず少しでも進めなければいけないのが辛いところです。
小学生に「微分・積分の問題を解きなさい」と強制しても無理なように、知らないことはできません。そんな業務できないと言いましょう。
>>Npgsql独自の部分があるようで、他のDB向けにかかれたサンプルではエラーになったり、動かなかったりしています。
単純に、DBの追加・更新・削除等だけなら、Npgsql独自の機能なんて不要だと思えますけどね。
独自部分を探して、とりあえずそれを抜きに動作するようにしてみれはどうでしょう?
>>実際のソースだけでなく、参考になるHP,サンプルソース等ありましたらお教え下さい。
私もネットや本やで参考になるサンプルを探したのですが、分かりやすくて参考になるサンプルソースは紹介した書籍でしかありませんでした。
お礼が遅くなりすみません。
>>小学生に「微分・積分の問題を解きなさい」と強制しても無理なように、知らないことはできません。そんな業務できないと言いましょう。
社会ではできないでは通用しない状況もあったりします。なかなか正論では通用しません。
>>単純に、DBの追加・更新・削除等だけなら、Npgsql独自の機能なんて不要だと思えますけどね。
独自部分を探して、とりあえずそれを抜きに動作するようにしてみれはどうでしょう?
通常のSQLコマンドでの操作はできています。
今回伺いたかったのは、DataGridView上でのデータ操作です。
>>私もネットや本やで参考になるサンプルを探したのですが、分かりやすくて参考になるサンプルソースは紹介した書籍でしかありませんでした。
あれからもいろいろと探して見ましたが、なかなかずばりのものはないですね。
C#のサンプルを見つけましたので、それをVBに移植してなんとか動きそうなところまでたどり着きました。
ありがとうございました。
No.1
- 回答日時:
>>PostgreSQL以外のDBはサンプルが沢山あるのですが・・・・
Npgsqlの説明をみると、
「.Net フレームワーク用に開発されたプログラムであればどんなものでもデータベースサーバにアクセスできます。」
と書かれています。
なので、DBがPostgreSQLであろうが、SQLServerであろうが、言語が同じサンプルなら問題なく動作するものと思いますよ。
>>ユーザが入力、修正し、配置したボタンを押すことでDBへ反映させたいのですが、この部分がよくわからなくて困っています。
これは、質問者さんがPostgreSQLというよりも、VB.NET2010のDBプログラムそのものの理解ができていないのだと思います。
「フォームロード時にDBの内容をDataGridViewへ表示させることまでできました。」
なんて書かれているくらいですからね。
実際問題として、.NETでDBを扱うのは、一見すると簡単そうに見えますが、実際には、DBプログラミングに関して、十分な知識が無いと無理だと思います。
.NET以前は、人間が頑張ってDBのプログラムのコードをガリガリと書いていた部分が、.NETではかなり自動生成されるようになりました。
が、それらのコードの果たす機能が不要になったわけではないので、その「見えなくなった機能」の部分を理解していないと訳解らなくなるってことです。
.NETでDBを扱われるのでしたら、「プログラミングADO.NET 2.0」(定価8,500円)を購入されて精読されることをお勧めします。
早速の回答、ありがとうございます。
>.NETでDBを扱われるのでしたら、「プログラミングADO.NET 2.0」(定価8,500円)を購入されて精読されることをお勧めします。
確かにいろいろな知識が不足しているため、勉強中ですが、業務はそれを待ってくれずとりあえず少しでも進めなければいけないのが辛いところです。
>DBがPostgreSQLであろうが、SQLServerであろうが、言語が同じサンプルなら問題なく動作するものと思いますよ。
Npgsql独自の部分があるようで、他のDB向けにかかれたサンプルではエラーになったり、動かなかったりしています。
>「フォームロード時にDBの内容をDataGridViewへ表示させることまでできました。」
事細かにプロセスを説明する場ではないと思ったので上のような表現をしました。
どのように表現するのが正しいのでしょうか?
実際のソースだけでなく、参考になるHP,サンプルソース等ありましたらお教え下さい。
よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Access(アクセス) アクセス テーブルの空白を変数に置換するボタンが作りたい 4 2022/07/08 11:19
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- Access(アクセス) 実行時エラー3131 FROM 句の構文エラーです について 7 2022/06/13 15:45
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Excel(エクセル) マクロのコードを、少しでも削って短くしたい 3 2022/08/30 07:46
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
- Visual Basic(VBA) 【マクロ】フォルダにファイルが1つも無い時に、ファイルがありませんとメッセージを表示する 4 2022/08/28 08:48
- Excel(エクセル) 【マクロ】フォルダAからダBへファイルを、ファイルの更新日時の条件で、1つづつ移動するには? 3 2022/08/25 09:56
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テストについて
-
グーグルの障害者訓練プログラ...
-
三菱製PLC:ファイルレジスタ(...
-
PostgreSQL+DataGridView
-
マスクROM と PROMの違いについて
-
Zと2とか紛らわしいのがあるか...
-
nc旋盤やレーザー加工機を使う...
-
マシニングセンタ プログラム...
-
初心者です。プログラムを作り...
-
プログラムを作ってもらう費用
-
ソケット通信の受信処理につい...
-
オーバレイ方式と仮想記憶シス...
-
プログラマーの土日のみのアル...
-
納品 vs ご納品 どちらが正し...
-
「スポット受注」はどういう意...
-
納入日と納品日について
-
スーパー発注し始めて3週間たち...
-
Windows server 2022 CALとSQL ...
-
中小企業に対しての分割検収
-
敬語チェックお願いします!
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Zと2とか紛らわしいのがあるか...
-
テストについて
-
三菱製PLC:ファイルレジスタ(...
-
プログラマーの土日のみのアル...
-
グーグルの障害者訓練プログラ...
-
オーバレイ方式と仮想記憶シス...
-
インプットとアウトプット
-
プログラムソースの値段
-
エントリーシート
-
初心者です。プログラムを作り...
-
PostgreSQL+DataGridView
-
三菱シーケンサーA1SHCPUとA1SJ...
-
マスクROM と PROMの違いについて
-
システムを作るにあたり、SQLSe...
-
プログラムのバージョンが上が...
-
東京でヨコイのソース買えますか?
-
マシニングセンタ プログラム...
-
フライに天つゆ
-
ナショナル NE-1401F の業...
-
3000行位の帳票作成プログラム...
おすすめ情報