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.74669 の関連記事表示
ヒット / 8件
(1-8 を表示)
<<
0
>>
■74669
CommitTransactionの使い方
□投稿者/ シャープ -
(2015/01/22(Thu) 10:37:46)
分類:[データベース全般]
2015/01/22(Thu) 10:57:29 編集(投稿者)
DB更新時の質問です。
VisualStudio環境からSqlConnectionのBeginTransaction()を行い、後続処理のある条件の場合は"DB変更処理なし"(SELECT処理は実施)と
するならば、その条件でもCommitTransaction()を使用すべきですか?
なるべく高速処理をしたいです。
DBはSQL Server2010です。
よろしくお願いします。
親記事 /過去ログ125より /
関連記事表示
削除チェック/
■74670
Re[1]: CommitTransactionの使い方
□投稿者/ shu -
(2015/01/22(Thu) 10:47:54)
■
No74669
(シャープ さん) に返信
言っている意味がよくわからないのですが
トランザクションを開始したのなら終了させるべきです。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74672
Re[2]: CommitTransactionの使い方
□投稿者/ シャープ -
(2015/01/22(Thu) 10:56:53)
■
No74670
(shu さん) に返信
> ■
No74669
(シャープ さん) に返信
>
> 言っている意味がよくわからないのですが
> トランザクションを開始したのなら終了させるべきです。
説明不足でした。
終了のさせ方として、RollbackTransaction()を使用した場合と処理速度に違いがあるのかを気にしていました。
"DB変更処理なし"の場合も、SELECT処理程度のDBアクセスはする前提でお願いします。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74673
Re[3]: CommitTransactionの使い方
□投稿者/ ぽぴ王子 -
(2015/01/22(Thu) 11:23:04)
>
■
No74672
(シャープ さん) に返信
> ■
No74670
(shu さん) に返信
>>■
No74669
(シャープ さん) に返信
>>
>>言っている意味がよくわからないのですが
>>トランザクションを開始したのなら終了させるべきです。
私もshuさんと同じ解釈をしていました :-)
> 終了のさせ方として、RollbackTransaction()を使用した場合と処理速度に違いがあるのかを気にしていました。
>
> "DB変更処理なし"の場合も、SELECT処理程度のDBアクセスはする前提でお願いします。
SqlConnection ということは SQL Server ということでいいのですよね。
SQL Server の中身まではわからないですが(他もわからないけれど)単純に考えた場合、コミットする内容がないとして
CommitTransaction も RollbackTransaction も速度に関してはさほど違いがあるようには思えないです。
や、厳密にいえば多少の違いはあるかもしれないですが、他の処理の方が問題になることが多いので、気にするほどではない
というレベルで、違いはないような気がします。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74674
Re[3]: CommitTransactionの使い方
□投稿者/ shu -
(2015/01/22(Thu) 11:34:29)
■
No74672
(シャープ さん) に返信
Selectするだけなら
コネクションを開いたまま複数selectして閉じれば
トランザクションは特にいらないかと思います。
処理速度を上げたければストアド、ユーザー定義関数を
用意するのがよいかと。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74675
Re[3]: CommitTransactionの使い方
□投稿者/ WebSurfer -
(2015/01/22(Thu) 12:09:25)
■
No74672
(シャープ さん) に返信
やりたいことがよく分かりません。
具体的なコード例を書いて(もしくは、Web にあるサンプルコードを引用して)「X 行目
の Commit は必要か?」と言うような感じで聞いていただくと理解しやすいのですが、可
能でしょうか?
> 終了のさせ方として、RollbackTransaction()を使用した場合と処理速度に違いがあるのかを気にしていました。
上記について、今の時点で一つだけ言えるのは、未コミットのトランザクションは接続が
Close される時にロールバックされます。
コネクションリーク防止のため、例外等何が起こっても必ず Close されるようにコーデ
ィングするはずですよね。
なので、一旦トランザクションを開始したら、コミットまたはロールバックのいずれかが
行われるはずです。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74677
Re[4]: CommitTransactionの使い方
□投稿者/ なちゃ -
(2015/01/22(Thu) 13:35:54)
単に、処理の最初でトランザクションは開始しているが、条件によっては結局何も更新処理を行わない場合があるが、そのときにどうするのがパフォーマンス上有利か?という疑問と言うことだと思います。
出ふつうに考えれば多分実質的な差はないと思いますが、当然DBの実装に依存はするので、結論は出せないです。
でまあ、変なことやるような価値はないと思いますので、何も考えずコミットで問題ないというのがふつうだと思います。
余談ですが、例えば更新データがある状況なら、コミットよりロールバックの方が時間がかかるということもあります、が応答時間では一概に言えない可能性もありますね、結局実装や状況依存ですね。
記事No.74669 のレス /過去ログ125より /
関連記事表示
削除チェック/
■74680
Re[5]: CommitTransactionの使い方
□投稿者/ シャープ -
(2015/01/22(Thu) 16:29:13)
■
No74677
(なちゃ さん) に返信
なちゃさん、返信ありがとうございます。
投稿して頂いた通りの内容で間違いございません。
代弁して頂いたような形になり、助かりました。
パフォーマンスに関しては、一概に何とも言えないということで了解しました。
DB更新処理をしない場合のトランザクション終了時に、最適化する定石があれば知りたいと思ったので、
お聞きした次第です。
極端に処理時間が遅くならないうちは、コミットで統一しようと思います。
ありがとうございました。
記事No.74669 のレス / END /過去ログ125より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-