在SQL Server 中,master 数据库记录系统级别的元数据,例如,logon accounts, endpoints, linked servers, and system configuration settings,同时,master 数据库记录其他数据库及其文件的位置,因此,在启动SQL Server实例时,master数据库必须最先启动。master 数据库是如此重要,必须频繁地备份master数据库。Only full database backups of master can be created.
一,备份master数据库
master数据库只能做full backup,不能做差异备份和事务日志备份,原因是master只能处于Recovered 状态,不能处于NoRecovery(recovering)状态。
<a></a>
二,还原master数据库
master数据库必须在单用户模式下还原,因此,在还原master数据之前,必须先停止SQL Server的所有服务(Service),包括MSSQLServer、Agent、Broser、Fulltext等,避免其竞争访问MSSQLService,然后,以管理员打开命令行;
step1,使用命令行net start,以single user 模式启动SQL Server实例的Service:MSSQLServer
参数/m“sqlcmd”:表示以单用户(Single User)模式启动Service,并且,只允许sqlcmd客户端访问service;
step2,使用sqlcmd登录到SQL Server实例
-E:指定sqlcmd以信任连接(trusted connection)方式登录Service,参数-E是默认的;
-S:指定sqlcmd连接的Server-Name
step3,使用sqlcmd还原master数据库,由于SQL Server实例中已经存在master数据库,必须指定replace选项,将原有的master数据库替换掉;
master数据还原完成之后,启动SQL Server实例的Service,就可以正常访问SQL Server实例。
参考文档:
<a href="http://blog.csdn.net/kk185800961/article/details/41920923">SqlServer系统数据库还原(三)系统数据库master-msdb-model 还原模拟测试</a>
<a href="https://msdn.microsoft.com/en-us/library/ms187837(v=sql.110).aspx" target="_blank">master Database</a>
<a href="https://msdn.microsoft.com/en-us/library/ms190679(v=sql.110).aspx" target="_blank">Restore the master Database (Transact-SQL)</a>
<a href="https://msdn.microsoft.com/en-us/library/ms188236(v=sql.110).aspx" target="_blank">Start SQL Server in Single-User Mode</a>
<a href="https://msdn.microsoft.com/en-us/library/ms162773(v=sql.110).aspx" target="_blank">sqlcmd Utility</a>
<a href="https://msdn.microsoft.com/en-us/library/ms180944(v=sql.110).aspx" target="_blank">Use the sqlcmd Utility</a>
本文版权归作者和博客园所有,欢迎转载,但未经作者同意,必须保留此段声明,且在文章页面醒目位置显示原文连接,否则保留追究法律责任的权利。
本文转自悦光阴博客园博客,原文链接:http://www.cnblogs.com/ljhdo/p/4549889.html,如需转载请自行联系原作者