Home >Database >Mysql Tutorial >改变当前Server下所有DB的物理路径的方案参考

改变当前Server下所有DB的物理路径的方案参考

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-06-07 15:48:381131browse

当你需要改变当前Server下所有DB的物理路径时,比如,从C盘搬到D盘,你会怎么办呢?或许你想到逐个对DB进行分离--〉搬文件--〉附加来实现,可是系统数据库并不能让你直接做分离这个动作,如下图所示。那怎么办呢?不急,这里提供一个可行的方案供大家参考。

当你需要改变当前Server下所有DB的物理路径时,比如,从C盘搬到D盘,你会怎么办呢?或许你想到逐个对DB进行分离--〉搬文件--〉附加来实现,可是系统数据库并不能让你直接做分离这个动作,如下图所示。那怎么办呢?不急,这里提供一个可行的方案供大家参考。

改变当前Server下所有DB的物理路径的方案参考

 

方案分3步进行:

  1. 通过SQL更新所有文件的路径
  2. 停掉SQL Server服务,手动将文件搬到目标位置
  3. 为master更改SQL Server的启动参数

检查当前Server中DB的文件位置:

select database_id,name, physical_name,case when type = 0 then 'DATA' when type = 1 then 'LOG' end as FileType 
from sys.master_Files

改变当前Server下所有DB的物理路径的方案参考

使用动态SQL生成ALTER DATABASE的脚本(排除master):

select 'Alter DATABASE ' + d.name + ' MODIFY FILE ( NAME = ' + f.name + ', FILENAME = ' +
' ''D:\NewFolder\'+  --这里是目标路径
right(physical_name, charindex('\',reverse(physical_name))-1 ) + ''' ) '
FROM sys.databases d
inner join sys.master_files f on d.database_id = f.database_id
where type = 0 and d.database_id  1

改变当前Server下所有DB的物理路径的方案参考
运行完ALTER DATABASE的脚本后,应该会看到一堆类似以下截图的消息:

改变当前Server下所有DB的物理路径的方案参考

下面,你可以停掉SQL Server服务,然后将物理文件搬到目标路径下。当所有文件(包括master)都搬完之后,再来修改启动参数

  1. 启动SQL Server配置管理器
    改变当前Server下所有DB的物理路径的方案参考
  2. 右击SQL Server实例--〉属性--〉启动参数,然后更新master .mdf的路径
    改变当前Server下所有DB的物理路径的方案参考

一旦你更新了启动参数,应该就可以了。不过,如果服务账号对新的路径没有访问权限,SQL Server将会启动失败。

PS:如果要对Production Server实施该方案,请事先在Test Server试验,并对Production Server进行完整备份,以备不测。

 

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn