ユーザーデータベースのファイルを移動しようとしたところ、
それぞれ次のエラーが返されます。
alter database USERDB modify file(name='USERDB_DATA',filename='D:\mdf\userdb.mdf')
=>MODIFY FILE に失敗しました。物理名を指定しないでください。
alter database USERDB modify file(name='USERDB_DATA')
=>ファイル 'USERDB_DATA'の MODIFY FILE に失敗しました。ファイルごとに少なくとも 1 つのプロパティを指定してください。
alter database USERDB modify file(filename='D:\mdf\userdb.mdf')
=>この CREATE/ALTER DATABASE ステートメントではファイル オプション NAME が必要です。
移動前にオフラインにしてみると、"データベース 'USERDB' はオフラインなので開けません。"とのエラーになります。
移動させるSQLコマンドの正しい構文をご教示下さい。
(指定しろとかするなとか一体...結局デタッチ・アタッチで済ませましたが、悔しいもので。。)
コメント(3件)
以前同じことをやったことがあり、そのときはこのようなことでひっかかった記憶はないのです。
(リストアやアタッチは例外で)
tempdbは特殊なんだと思います。
tempdbはSQLServer起動時に削除>作成されるので、物理名を変更した場合、再起動後、新しい名前が有効になるはずです。
コメント有難う御座います。
以前一般DBファイルにも出来た記憶があったもので(記憶が怪しいのかもしれませんが...)
ちょっとした文法間違いかな...といった感じで質問してみました。
ちなみに、SQLServer2005は全く問題なくできます。
SQLServer2000のほうは、運用を開始してもうDBファイルを動かすことがしばらくなくなったので
何かの機会にトライしてみたいと思います。