修改sql server的数据文件路径

以下以testdb数据库为例:

数据的默认路径:C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\DATA

1 查询数据库文件路径(在数据库客户端ssms操作)
select name,physical_name as CurrentLocation from sys.master_files where database_id=DB_ID('数据库名称,如testdb');

如查询出的

1.1  name为testdb对应的physical_name 为:C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\DATA\testdb.mdf

1.2  name为testdbLog 对应的physical_name 为:C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\DATA\testdb.ldf


2 修改路径(在数据库客户端ssms操作)
Alter database testdb modify file (name=testdb,filename='E:\zxy\Database\DATA\testdb.mdf');

Alter database testdb  modify file (name=testdbLog,filename='E:\zxy\Database\DATA\testdb.ldf');

3  停止sql server的window后台服务SQL Server(MSSQLSERVER),不然无法拷贝,如下图:

然后在默认路径C:\Program Files\Microsoft SQL Server\MSSQL14.MSSQLSERVER\MSSQL\DATA拷贝数据库文件testdb.mdf、testdb.ldf到目录E:\zxy\Database\DATA

4 给目录E:\zxy\Database\DATA授权,授everyone的权限

5 重启启动window后台服务SQL Server(MSSQLSERVER),进入ssms,将数据库设置为联机状态:
alter database  testdb  set online;

### 更改 SQL Server 数据库文件的位置或路径 为了更改 SQL Server 数据库文件的存储路径,可以按照如下方式操作: 在 SSMS (SQL Server Management Studio) 中,通过图形界面调整默认数据库文件保存路径。具体而言,在SSMS中,右键点击服务器节点并选择属性[^1]。 随后进入“数据库设置”,在此处能够重新指定数据文件以及日志文件的新默认位置。 完成上述设定之后,需重启 SQL Server 服务来让新的配置生效。这一步骤至关重要,因为只有经过重启,系统才会识别更新后的默认路径设置。 另外一种更为灵活的方法涉及直接移动现有数据库的数据和日志文件到新位置,并相应地通知 SQL Server 这些文件的新地址。此过程通常包括以下几个方面的工作: 对于每一个要迁移数据库,先执行 `ALTER DATABASE` 命令中的 `SET OFFLINE` 子句将其置为离线状态;接着物理上复制这些文件至目标目录;最后再次利用 `ALTER DATABASE` 的 `MODIFY FILE` 来指明各文件最新的存放地点,并通过 `SET ONLINE` 将其恢复在线状态以便正常使用。 以下是用于将某个特定数据库设为离线、修改文件路径后再转回在线的一个简单例子: ```sql USE master; GO -- 设置数据库为脱机模式 ALTER DATABASE YourDatabaseName SET OFFLINE WITH ROLLBACK IMMEDIATE; GO -- 修改文件逻辑名对应的物理路径 ALTER DATABASE YourDatabaseName MODIFY FILE ( NAME = 'YourDataFileName', FILENAME = 'C:\NewPath\YourDataFile.mdf' ); ALTER DATABASE YourDatabaseName MODIFY FILE ( NAME = 'YourLogFileName', FILENAME = 'D:\AnotherPath\YourLogFile.ldf' ); GO -- 设置数据库为联机模式 ALTER DATABASE YourDatabaseName SET ONLINE; GO ``` 请注意替换命令里的 `'YourDatabaseName'`, `'YourDataFileName'`, 和其他占位符为你实际使用的名称与路径
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zxy2847225301

测试使用

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值