• SQL Server 中如何移动tempdb到新的位置


    操作步骤:
    1、检查tempdb的逻辑名字和它的存在位置。可以使用下面语句:

    SELECT name, physical_name
    FROM sys.master_files
    WHERE database_id = DB_ID('tempdb');

    2、停止数据库服务.


    3、拷贝原来tempdb的文件到新的位置(原来文件位置可以通过上述查询得到)。拷贝完毕后,启动数据库服务。


    4、执行如下命令:

    USE master;
    GO
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = tempdev, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb.mdf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp2, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_2.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp3, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_3.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp4, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_4.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp5, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_5.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp6, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_6.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp7, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_7.ndf');
    
    ALTER DATABASE tempdb 
    MODIFY FILE (NAME = temp8, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	empdb_mssql_8.ndf');
    
    GO
    ALTER DATABASE  tempdb 
    MODIFY FILE (NAME = templog, FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库	emplog.ldf');
    GO

    在这里,name=tempdev 和templog 等是tempdb的逻辑名字,FILENAME = N'D:Microsoft SQL ServerMSSQL13.MSSQLSERVERMSSQL系统临时数据库 empdb.mdf'是tempdb的新位置.

    执行结果如下:

    5、然后检查tempdb移动是否成功。

    SELECT name, physical_name
    FROM sys.master_files
    WHERE database_id = DB_ID('tempdb');

    6、接着重启数据库服务

    7、注意在步骤3中,我们重新启动数据库服务的时候,还是会在老的tempdb路径下生成一套tempdb的数据库文件,现在它们都是没用的垃圾文件了,我们要去删掉它们。

    特别提示:

    存放SQL Server数据库文件及数据库日志文件的文件夹,必须要开放对Windows用户组"NT ServiceMSSQLSERVER"(也就是SQL Server服务的执行账户)的Full control权限,否则会导致上面步骤6中重启SQL Server服务失败。

    如果你不知道SQL Server服务的执行账户是什么,可以通过在Windows服务(services)管理列表中,找到SQL Server数据库引擎服务(如果你只有一个SQL Server Instance,一般就是"SQL Server (MSSQLSERVER)"),然后查看其"Log On As"列的账户:

    如果你发现SQL Server执行账户不是上图中的"NT ServiceMSSQLSERVER",那么需要将存放SQL Server数据库文件及数据库日志文件的文件夹,开放相应Windows账户的Full control权限。

    这一点要千万注意,否则SQL Server服务启动不起来会非常麻烦,如果实在因为移动tempdb到新位置后,SQL Server服务启动不起来,可以参考下面这个帖子的内容:

    How to Start SQL Server without TempDB

  • 相关阅读:
    android中图型的阴影效果(shadow-effect-with-custom-shapes)
    git的经常使用命令
    C# vs Java
    Android-68-Tomcat各种启动错误的解决的方法,如:Exception in thread "Thread-6" NoClassDefFoundError,Document base E:
    Java高级程序猿技术积累
    Floodlight下发流表过程分析
    Maximal Rectangle [leetcode] 的三种思路
    C++实现顺序栈的基本功能
    ZOJ 1654 Place the Robots(最大匹配)
    [2-SAT] poj 3207 Ikki's Story IV
  • 原文地址:https://www.cnblogs.com/OpenCoder/p/10322904.html
Copyright © 2020-2023  润新知