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.83438 の関連記事表示
ヒット / 11件
(1-11 を表示)
<<
0
>>
■83438
非同期のDBアクセスの記述方法
□投稿者/ ぼよん -
(2017/03/23(Thu) 17:00:02)
分類:[C#]
VS2016のC#を使ってDBアクセスのサンプルを作っています。
実は・・・私はほとんどC#を書いたことがなくて、過去にVB6で作ったツールをC#の勉強しつつ作り直そうとしています。
コードはしょりますが、使うオブジェクトは以下です。
using IBM.Data.DB2;
DB2Connection con;
DB2DataReader reader = null;
cmd = con.CreateCommand()
cmd.CommandText = azukiScript.Text;
同期処理なら、
reader = cmd.ExecuteReader();
これで、うまく操作できました。
非同期の場合がどうやればよいのかわかりません。
Task task = cmd.ExecuteReaderAsync();
と、書くのでしょうか???
その場合、後続はどう書くべきなんでしょうか?
ExecuteReaderAsync で検索しても、使用例がまったくHitしないためさっぱりです。
どなたかよきアドバイスをお願いします。
親記事 /過去ログ143より /
関連記事表示
削除チェック/
■83535
Re[1]: 非同期のDBアクセスの記述方法
□投稿者/ shu -
(2017/03/27(Mon) 13:49:37)
■
No83438
(ぼよん さん) に返信
> 非同期の場合がどうやればよいのかわかりません。
> Task task = cmd.ExecuteReaderAsync();
> と、書くのでしょうか???
> その場合、後続はどう書くべきなんでしょうか?
ExecuteReaderAsyncは使ったことがないですが
これはTask型のインスタンスが作成されているだけなので
多分実行はされていないのではないでしょうか?
Startで実行して
ContinueWithで継続処理を続けていくと思われます。
別スレッドを作成してその中でExecuteReaderを
行ったほうがよいかもしれません。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83555
Re[2]: 非同期のDBアクセスの記述方法
□投稿者/ もりお -
(2017/03/27(Mon) 23:02:12)
■
No83535
(shu さん) に返信
ExecuteReaderAsyncは内部でTaskFactory.FromAsyncを呼び出していて
↓こんなの見つけました
https://msdn.microsoft.com/ja-jp/library/dd997423
(v=vs.110).aspx
| FromAsync タスクの開始とキャンセル
|
| FromAsync メソッドから返されるタスクの状態は WaitingForActivation で、
| タスク作成後のある時点でシステムによって開始されます。
| このようなタスクで Start を呼び出そうとすると、例外が発生します。
実行は自動的にされるみたいです。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83563
Re[3]: 非同期のDBアクセスの記述方法
□投稿者/ ぼよん -
(2017/03/28(Tue) 11:14:41)
おふた方、ありがとうございます。
少し調べてみましたが、前提スキルが低すぎて理解がおよびません。
「非同期」を私が取り違えてるのでしょうか。
ほにゃららAsync のメソッドがいくつか用意されているもののこれらは何が違うのでしょうか。
VB6+RDO で作ってたツールを非同期で組んでたので、そのままC#で作り直そうとしています。
SQLの実行結果は RDOのコネクションオブジェクトからイベントハンドラーで通知されるような仕組みでした。
なんとなく task や async などかなあと 調べつつ進めるも、サンプルがなさすぎます。
世間一般ではやらないのでしょうかね???
独学ははじめの一歩が一番しんどいですね。
ハードル高いなぁ・・・と感じてます。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83567
Re[4]: 非同期のDBアクセスの記述方法
□投稿者/ なちゃ -
(2017/03/28(Tue) 13:28:17)
Taskを利用する非同期処理そのままなので 、Taskの例や使い方を見るのが早いです。
戻り値有りのTaskの使い方と同じです。
awaitとかと組み合わせて使ったりします。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83570
Re[5]: 非同期のDBアクセスの記述方法
□投稿者/ ぼよん -
(2017/03/28(Tue) 14:51:11)
■
No83567
(なちゃ さん) に返信
> Taskを利用する非同期処理そのままなので 、Taskの例や使い方を見るのが早いです。
そうします!
ここに良さそうな情報がありましたので試してみますね。
http://www.kekyo.net/2016/12/06/6186
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83591
Re[6]: 非同期のDBアクセスの記述方法
□投稿者/ 渋木宏明 -
(2017/03/29(Wed) 22:34:11)
async/await 構文を使うのが推奨です。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83632
Re[7]: 非同期のDBアクセスの記述方法
□投稿者/ ぼよん -
(2017/03/31(Fri) 11:59:06)
その後、いくつかのサイトを参考にTASKを勉強してました。
ここを見ながら async/await をためしました。
http://www.atmarkit.co.jp/ait/subtop/features/dotnet/app/masterasync_index.html
reader = DBCommand.ExecuteReader は動作したのですが、その結果をDataGridやStripなどのUIに展開するときに
「コントロールが作成されたスレッド以外のスレッドからコントロール xxxxx がアクセスされました。」
のエラーが出てこけます。
UIスレッド以外で、コントロールに触れてはいけないみたいですね。
※正直なところスレッドの意味もよくわかっていませんでした。プロセスの1階層下でCPUが割り振られるぐらいに考えてます。
じゃあ、どうするのと調べてたら、Invokeやdelegateなどのキーワードが出てきます。
このあたりはまだ意味がよく判っていません。
やりたいことはDBへのSELECTした結果をGRIDに展開するまで、UIを止めず、途中でキャンセルができるようにしたいのです。
基本的な考え方というか、作り方が間違ってるんじゃないかなとも思ったりしています。
ご意見いただけないでしょうか。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83633
Re[8]: 非同期のDBアクセスの記述方法
□投稿者/ shu -
(2017/03/31(Fri) 12:24:31)
■
No83632
(ぼよん さん) に返信
> やりたいことはDBへのSELECTした結果をGRIDに展開するまで、UIを止めず、途中でキャンセルができるようにしたいのです。
> 基本的な考え方というか、作り方が間違ってるんじゃないかなとも思ったりしています。
>
BackgroundWorkerを使って
DoWorkで読み取りを行い
RunWorkerCompletedでUIへの設定を行うのがよいかと思います。
BackgroundWorkerのMSDNの例
https://msdn.microsoft.com/ja-jp/library/cc221403
(v=vs.95).aspx?cs-save-lang=1&cs-lang=vb#code-snippet-3
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83635
Re[9]: 非同期のDBアクセスの記述方法
□投稿者/ ぼよん -
(2017/03/31(Fri) 13:50:24)
ありがとうございます。BackgroundWorkerですか。いろいろあるもんですね。
Query待ちのキャンセル方法を調べていませんが、
BackgroundWorkerの中で処理すればQuery待ちでも、結果の描画でも、
ひとつのCancelAsyncで止めれるのかなと思いました。
そうなると、DBのほにゃららAsyncメソッドの出番がまったくないんですがどう使い分けるんでしょうね。
とにかく、試してみたいと思います。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
■83639
Re[10]: 非同期のDBアクセスの記述方法
□投稿者/ なちゃ -
(2017/03/31(Fri) 15:57:24)
〜Asyncが提供されている場合は基本的にそれが一番効率がいいですしasync/awaitと組み合わせたら簡単に使えます。
var reader = await cmmand.ExecuteReaderAsync();
// ここからreader使った処理
ってやるだけです基本的には。
記事No.83438 のレス /過去ログ143より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-