「Microsoft SQL Server」が稼働するデータベースシステムを運用する管理者に向け、「動的管理ビュー」の活用を軸にしたトラブル対策のためのノウハウを紹介していきます。今回は、FILE TABLEのハンドルの一覧に関する情報の出力について解説します。
この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。
本連載では、「Microsoft SQL Server(以下、SQL Server)」で使用可能な動的管理ビューについて、動作概要や出力内容などを紹介していきます。今回は動的管理ビュー「sys.dm_filestream_non_transacted_handles」における、FILE TABLEのハンドルの一覧に関する情報の出力について解説します。対応バージョンは、SQL Server(サポートされている全てのバージョン)です。
SQL ServerではFILESTREAMの機能を使用することで、非構造化データ(ドキュメントやイメージなど)をファイルシステムに格納できます。FILESTREAMの機能によって、ファイルシステムのストリーミングAPIをアプリケーションで活用できるほか、非構造化データとそれに対応する構造化データの間でトランザクションの一貫性を維持できます。
FILESTREAMの機能を使用するには、SQL ServerインスタンスでFILESTREAM機能を有効化して、データベースやテーブルにFILESTREAMデータを格納できるように構成する必要があります。
FILESTREAMの機能を使用したFILE TABLEはトランザクションを使用せずに非構造化データをファイルシステムに格納できます。「sys.dm_filestream_non_transacted_handles」ではFILE TABLEのハンドルの一覧に関する情報を出力します。
列名 | データ型 | 説明 |
---|---|---|
database_id | int | データベースのID |
object_id | int | オブジェクトID |
handle_id | int | ハンドルのID |
file_object_type | int | ハンドルの型 |
file_object_type_desc | nvarchar(120) | ハンドルの型の説明。次のいずれかになる UNDEFINED SERVER_ROOT DATABASE_ROOT TABLE_ROOT TABLE_ITEM |
correlation_process_id | varbinary(8) | 要求したプロセスのID |
correlation_thread_id | varbinary(8) | 要求したスレッドのID |
file_context | varbinary(8) | ファイルオブジェクトへのポインター |
state | int | ハンドルの状態 |
state_desc | nvarchar(120) | ハンドルの状態の説明。次のいずれかになる ACTIVE CLOSED KILLED |
current_workitem_type | int | ハンドルが処理されている状態 |
current_workitem_type_desc | nvarchar(120) | ハンドルが処理されている状態の説明。次のいずれかになる NoSetWorkItemType FFtPreCreateWorkitem FFtGetPhysicalFileNameWorkitem FFtPreCleanupWorkitem FFtPostCleanupWorkitem FFtPreCloseWorkitem FFtQueryDirectoryWorkItem FFtQueryInfoWorkItem FFtQueryVolumeInfoWorkItem FFtSetInfoWorkitem FFtWriteCompletionWorkitem |
fcb_id | bigint | ファイル制御ブロックのID |
item_id | varbinary(892) | ファイルまたはディレクトリのID |
is_directory | bit | ディレクトリかどうか |
item_name | nvarchar(512) | 項目の名前 |
opened_file_name | nvarchar(512) | 要求されたパス |
database_directory_name | nvarchar(512) | データベースのディレクトリ名 |
table_directory_name | nvarchar(512) | テーブルのディレクトリ名 |
remaining_file_name | nvarchar(512) | 残りのディレクトリ名 |
open_time | datetime | ハンドルが開かれた時刻 |
flags | int | 次の値を示すフラグ ShareFlagsUpdatedToFcb = 0x1 DeleteOnClose = 0x2 NewFile = 0x4 PostCreateDoneForNewFile = 0x8 StreamFileOverwritten = 0x10 RequestCancelled = 0x20 NewFileCreationRolledBack = 0x40 |
login_id | int | ログインのID |
login_name | nvarchar(512) | ログインの名前 |
login_sid | varbinary(85) | ログインのSID |
read_access | bit | 読み取りアクセス用 |
write_access | bit | 書き込みアクセス用 |
delete_access | bit | 削除アクセス用 |
share_read | bit | 共有読み取り許可 |
share_write | bit | 共有書き込み許可 |
share_delete | bit | 共有削除許可 |
FILE TABLEが設定されているSQL Serverで、エクスプローラーからファイルを保存して「sys.dm_filestream_non_transacted_handles」を実行すると、FILE TABLEのハンドルの一覧に関する情報が出力されました(図1)。
FILE TABLEでロックが保持されている場合、「sys.dm_filestream_non_transacted_handles」の「fcb_id」列と「sys.dm_tran_locks」の「request_owner_id」列を結合させてロックの状況を確認できる場合があります。
※本Tipsは、「Windows Server 2019」上に「SQL Server 2019」をインストールした環境を想定して解説しています。
日本ユニシス株式会社所属。Microsoft MVP for Data Platform(2017〜)。入社以来 SQL Serverの評価/設計/構築/教育などに携わりながらも、主にサポート業務に従事。SQL Serverのトラブル対応で社長賞の表彰を受けた経験も持つ。休日は学生時代の仲間と市民駅伝に参加し、銭湯で汗を流してから飲み会へと流れる。
日本ユニシス株式会社所属。入社以来SQL Server一筋で評価/設計/構築/教育などに携わりながらも、主にサポート業務に従事。社内のプログラミングコンテストで4回の優勝経験も持つ。趣味は輪行で週末は自転車を持っての旅行。目標は色々な日本百選を制覇すること。
Copyright © ITmedia, Inc. All Rights Reserved.