C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.31890 の関連記事表示
ヒット / 4件
(1-4 を表示)
<<
0
>>
■31890
ADO.NETでのDB接続やINSERTについて
□投稿者/ toro2 -
(2009/01/29(Thu) 19:02:49)
分類:[C#]
ADO.NETの初心者です。
@itなどを参考にDB接続などのプログラムを作成していますが、
いまいちよくわかりません。
(C# PostgreSQL)
個別に処理する部分等はわかるのですが、実際の処理方法がピンと
こないというのが現実です。
やりたいことは
1.1行ずつテキスト(複数)を読み込んでそれをDBに大量にINSERTする。
2.パラメータを使って処理したい。
です。
ADO,NETは非接続型であるのは理解しましたが、よくある部分で
INSERTしたら接続を切断していますが、そのようなものですか?
また、DataAdapterクラスを使って、パラメータを使用して、
テーブルなどで一気にINSERTしたいと思っていましたが、これは最初に
必ずselectでその該当のテーブルを全部取得しないといけないのでしょうか?
何か簡単なプログラムを提供していただけると助かります。
よろしくお願いします。
親記事 /過去ログ57より /
関連記事表示
削除チェック/
■31919
Re[1]: ADO.NETでのDB接続やINSERTについて
□投稿者/ まさる -
(2009/01/30(Fri) 10:33:44)
>
2009/01/30(Fri) 10:40:38 編集(投稿者)
あ、勘違いしていたみたいです。ごめんなさい。
1. テキストから1行(または必要な行数)読み込む。
2. 1のデータを元にINSERT用のDbCommand(PostgreSQL用のデータプロバイダを使っていれば別の名前です)を組み立てる。
3. 2のDbCommandのExecuteNonQueryメソッドを実行する。
4. 対象データがなくなるまで、1〜3を繰り返す
といった感じだと思います。
以下は忘れてください。
---
やりたいことの意図がいまいち読み取れません。
1.パラメータで条件を指定し、データを抽出。
2.抽出したデータを元にINSERT処理
ということでしょうか?
であるならば、DataReaderを使った逐次処理の方が、DataAdapterなどを使ってまとめてデータを取ってくるよりは効率的だと思われます。
処理の流れとしては、
1.Connectionオープン
2.Connection.CreateCommand()でSelectCommand作成
3.作ったSelectCommandにデータ抽出用のSELECT文を設定。
ここで、パラメータも指定する。
4.SelectCommand.ExecuteReader()でDataReader取得
5.DataReader.Read()でデータを読み込む
6.Connection.CreateCommand()でInsertCommand作成
7.InsertCommandに、DataReaderの読み込み結果を元に、INSERT文とパラメータ指定
8.InsertCommand.ExecuteNonQuery()を実行しデータを登録
9.読み取り可能なデータがなくなるまで、5〜8を繰り返す
といった流れになるかと思います。
http://msdn.microsoft.com/ja-jp/library/system.data.sqlclient.sqldatareader%28VS.80%29.aspx
を参考にしてください。SQL Server用の説明になってますが、PostgreSQL用のものでも考え方は変わらないはずです。
■
No31890
(toro2 さん) に返信
> ADO.NETの初心者です。
> @itなどを参考にDB接続などのプログラムを作成していますが、
> いまいちよくわかりません。
> (C# PostgreSQL)
>
> 個別に処理する部分等はわかるのですが、実際の処理方法がピンと
> こないというのが現実です。
>
> やりたいことは
>
> 1.1行ずつテキスト(複数)を読み込んでそれをDBに大量にINSERTする。
> 2.パラメータを使って処理したい。
>
> です。
>
> ADO,NETは非接続型であるのは理解しましたが、よくある部分で
> INSERTしたら接続を切断していますが、そのようなものですか?
>
> また、DataAdapterクラスを使って、パラメータを使用して、
> テーブルなどで一気にINSERTしたいと思っていましたが、これは最初に
> 必ずselectでその該当のテーブルを全部取得しないといけないのでしょうか?
> 何か簡単なプログラムを提供していただけると助かります。
> よろしくお願いします。
記事No.31890 のレス /過去ログ57より /
関連記事表示
削除チェック/
■31945
Re[1]: ADO.NETでのDB接続やINSERTについて
□投稿者/ はつね -
(2009/01/30(Fri) 11:54:48)
>
■
No31890
(toro2 さん) に返信
> ADO,NETは非接続型であるのは理解しましたが、よくある部分で
> INSERTしたら接続を切断していますが、そのようなものですか?
INSERTしたら接続を切断ではなく、あるアクションに関連する変更を行ったら切断ですね。
今回の場合「DB接続を行って、テキストファイルを指定してそれを1行づつ読み込みながらINSERTしてすべての行が処理し終わったら、DB接続を切断」になると思います。
> また、DataAdapterクラスを使って、パラメータを使用して、
> テーブルなどで一気にINSERTしたいと思っていましたが、
DataAdapterクラスを使う場合、その前にDataSetに対して値をINSERTしておかなくてはなりません。
値をINSERTするためには、事前にDataSetにテーブルのコピーを保持しておく必要があります。
保持しないと既にテーブルにあるレコードをINSERTしようとして失敗します。
# 常にからのテーブルに行い、なおかつ、必ず1箇所から行うなら事前にDatasetに保持は不要でしょうけれど。
記事No.31890 のレス /過去ログ57より /
関連記事表示
削除チェック/
■32393
Re[2]: ADO.NETでのDB接続やINSERTについて
□投稿者/ toro2 -
(2009/02/05(Thu) 22:29:32)
ごめんなさい。返信したつもりで忘れていました。
返信していただいたまさる さん、はつね さんありがとうございました。
まだまだかなりの初心者なのですが、やってみます。
記事No.31890 のレス / END /過去ログ57より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-