MSSQLSERVER_5120
適用対象: SQL サーバー
詳細
属性 | Value |
---|---|
製品名 | SQL Server |
イベント ID | 5120 |
イベント ソース | MSSQLSERVER |
コンポーネント | SQLEngine |
シンボル名 | DSK_FCB_FAILURE |
メッセージ テキスト | テーブル エラー: 物理ファイル "%.*ls" を開くことができません。 オペレーティング システム エラー %d: "%ls"。 |
説明
SQL Server でデータベース ファイルを開くことができませんでした。 メッセージに示されたオペレーティング システム エラーにより、エラーのより具体的な根本原因が示されます。 このエラーは、17204 や 17207 などの他のエラーと共に表示されることがよくあります。
ユーザー アクション
オペレーティング システム エラーを診断して修正してから、操作を再試行してください。 Microsoft で領域の発生している製品の領域を絞り込むのに役立つ、複数の状態があります。
アクセスが拒否されました
Access is Denied
オペレーティング システム エラー = 5 を取得している場合は、次の方法を検討してください。
エクスプローラーでファイルのプロパティを参照して、ファイルに設定されているアクセス許可を確認します。 SQL Server では、Windows グループを使用して、さまざまなファイル リソースにアクセス制御をプロビジョニングします。 適切なグループ [SQLServerMSSQLUser$ComputerName$MSSQLSERVER や SQLServerMSSQLUser$ComputerName$InstanceName などの名前] に、エラー メッセージで言及されているデータベース ファイルに対して必要なアクセス許可が付与されていることを確認します。 詳細については、「データベース エンジン アクセスのファイル システム権限の構成」を参照してください。 Windows グループに SQL Server サービスのスタートアップ アカウントまたはサービス SID が実際に含まれていることを確認します。
SQL Server サービスが現在実行されているユーザー アカウントを確認します。 Windows タスク マネージャーを使用して、この情報を取得できます。 実行可能ファイル "sqlservr.exe" の "ユーザー名" の値を探します。 また、SQL Server サービス アカウントを最近変更した場合は、この操作を行うためにサポートされている方法は、SQL Server 構成マネージャー ユーティリティを使用することです。
操作の種類 (サーバー起動中にデータベースを開く、データベースのアタッチ、データベースの復元など) によっては、偽装とデータベース ファイルへのアクセスに使用されるアカウントが異なる場合があります。 トピック「データ ファイルとログ ファイルのセキュリティ保護」を確認して、どの操作によってどのアクセス許可が、どのアカウントに設定されるかを理解してください。 Windows SysInternals Process Monitor などのツールを使用して、SQL Server インスタンスのサービス開始アカウント [またはサービス SID]、または偽装されたアカウントのセキュリティ コンテキストにおいて、ファイルへのアクセスが行われているかどうかを把握します。
SQL Server によって、ALTER DATABASE または CREATE DATABASE 操作を実行するログインのユーザー資格情報が偽装されている場合は、Process Monitor ツールに次の情報が表示されます (一例)。
Date & Time: 3/27/2010 8:26:08 PM Event Class: File System Operation: CreateFile Result: ACCESS DENIED Path: C:\Program Files\Microsoft SQL Server\MSSQL13.SQL2016\MSSQL\DATA\attach_test.mdf TID: 4288 Duration: 0.0000366 Desired Access:Generic Read/Write Disposition: Open Options: Synchronous IO Non-Alert, Non-Directory File, Open No Recall Attributes: N ShareMode: Read AllocationSize: n/a Impersonating: DomainName\UserName
ネットワークに接続された記憶域に存在するファイルをアタッチする
ネットワークに接続された記憶域に存在するデータベースを再アタッチできない場合は、このようなメッセージがアプリケーション ログに記録される可能性があります。
Msg 5120, Level 16, State 101, Line 1 Unable to open the physical file "\\servername\sharename\filename.mdf". Operating system error 5: (Access is denied.).
この問題は、データベースのデタッチ時に SQL Server によってファイルのアクセス許可がリセットされるために発生します。 データベースを再アタッチしようとすると、共有のアクセス許可が制限されているためにエラーが発生します。
解決するには、次の手順に従ってください。
-T スタートアップ オプションを使用して SQL Server を起動します。 このスタートアップ オプションを使用して、SQL Server 構成マネージャー でトレース フラグ 1802 を有効にします (1802 の詳細については、トレース フラグを参照してください)。 スタートアップ パラメーターの変更方法の詳細については、「データベース エンジン サービスのスタートアップ オプション」を参照してください。
次のコマンドを使用して、データベースをデタッチします。
exec sp_detach_db DatabaseName go
次のコマンドを使用して、データベースを再アタッチします。
exec sp_attach_db DatabaseName, '\\Network-attached storage_Path\DatabaseMDFFile.mdf', '\\Network-attached storage_Path\DatabaseLDFFile.ldf' go