C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.23586 の関連記事表示

<< 0 >>
■23586  Re[5]: 100万件データのInsertでタイムアウト
□投稿者/ 黒龍 -(2008/08/18(Mon) 23:15:23)
    コマンド以外にもトランザクションのタイムアウトもありますね。

    No23585 (片桐 さん) に返信
    > まず、commandtimeout=0 で実行すると、終了するまで処理は待機しますので、いつか処理が終われます
    > CLRで作っても、ストアドには違いないので、その当たりは強固に作られているから大丈夫です。
    > 実際、私も430万件レコードのINSERTをCLRで実行したことがありますから、そこは確約できます
    >
    > SQLの解析方法はいくつかありますが、プロファイラを使用しているなら、
    > 取得するイベントを選択して流せば色々な情報が得られます。
    > その中にはShowPLANもあって、実行するSQLの解析結果も表示できます
    >
    > 切羽詰っているときこそ、こういったツールを使って正確な情報を把握していかなくてあはならないです、がんばってください
    >
    > MTAとはMultiThreadApartment、つまり、複数のスレッドを実行して並行処理を行う方法です。
    > これを使い、インデックスをわざとはずして、MTAで主キーで分割したSELECTレコードを並行にINSERTしてインデックスを戻す、という手を使いました。INSERTのSQLは中には一切計算式をいれず、すべて事前にスキーマバインドビューを使って単純なSELECTINSERTにまで落とし込んで処理しています。コミットタイミングをずらしてCXPACKET発生をギリギリまで抑えてスピードをはかり、最終的には430万件のレコードチェック&集計&INSERT処理を10分切るところまでチューンアップしましたがかなり色々と姑息な手が必要でした。
    >
    > ところどころの情報は私のブログにちょこちょこと書いています。
    > が、それらの大元の情報はほとんど海外サイトです。
    >
記事No.23487 のレス /過去ログ45より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -