質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

Q&A

解決済

1回答

783閲覧

EXCEL ADODB.ConnectionのカーソルについてadOpenForwardOnlyとadOpenStaticsの違い

skyblue77

総合スコア1

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

0グッド

0クリップ

投稿2020/05/28 07:27

カーソルに関して質問です。
EXCELでSQLServerにADODB.Connectionにて接続して、データベース上のデータを取得(SELECT)を行っております。
別のアプリで更新データが1分おき程度に挿入、更新、削除がなされているDBです。

 今回そんなDBからのSELECTを実施したく以下2つのカーソルで悩み中です。
以下2つのカーソルで、時間差が5秒ほど発生し、デフォルトのadOpenForwardOnlyの方が早いのですが、
データ的に中途半端なテーブル状態は取得したくなく。また、DBロックで業務が止まるのも避けたく。
数秒早いadOpenForwardOnlyがデフォルトなので、こちらを使いたいのですが、
adOpenStaticsのopenした時点のテーブルを維持するのであれば
Statics側が整合性がとれているのでこちらを使うべきなのか?

 2つをどう使い分ければよいかわからず、質問に至りました。

 adOpenForwardOnly:規定で、前方へのカーソルのみ
adOpenStatics  :openした時点のテーブルを取得(tempdbに一時書き込み)

adOpenForwardOnlyを使う場合、読み込み最中に、DB側で更新、削除が行われた場合、
それが反映されたかされないか、中途半端なデータを取得してくるのでしょうか?

 adOpenStaticsはopenした際に、その時点の表として整合性が取れたものを取得してくるのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

adOpenForwardOnlyですが、MSのドキュメントでは、以下のように説明されています。

「既定値。 順方向専用カーソルを使用します。 レコードをスクロールするだけでスクロールできる点を除いて、静的カーソルと同じです。 」

つまり、adOpenStatics+カーソル移動方向固定です。
また、adOpenStaticsの説明には、以下の記述があります。

「これは、データの検索やレポートの生成に使用できる一連のレコードの静的なコピーです。 他のユーザーによる追加、変更、または削除は表示されません。」

結論としては、どちらを使っても、取得時時点のデータを保持し続けますので、整合性の問題に差はありません。
あとは、処理内で、逆方向移動があるかないかで決めれば良いでしょう。

CursorTypeEnum

投稿2020/05/28 10:57

YT0014

総合スコア1708

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

skyblue77

2020/05/29 00:31

回答、ありがとうございました。 MSのドキュメントに回答があるなんて気が付きませんでした。 スピード改善に役立ちました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問