LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

利用SQLCMD为SQL Server Express分离和附加数据库文件

admin
2013年4月2日 22:15 本文热度 4973

在分离和附加数据库时可以使用sp_detach_db,sp_attach_db和sp_attach_single_file_db系统存储过程,这三个存储过程对于SQL Server数据库管理员执行以下的任务是非常方便的:


1.使用sp_detach_db将数据库从一个服务器分离;


2.使用sp_attach_db系统存储过程直接将.mdf和.ldf文件附加到数据库服务器;


3.使用sp_attach_single_file_db系统存储过程只附加.mdf文件;


尽管它们对于SQL Server数据库管理员是很有用的,但是在使用这两个存储过程时是有一些限制的,:


1.不能附加多个日志文件;


2.不能附加16个以上的文件;


在SQL Server 2008中,微软宣布上面的系统存储过程将在未来的版本中被废弃.而在"CREATE DATABASE"SQL语句中添加了一个从句"FOR ATTACH".并建议应该使用"CREATE DATABASE database_name FOR ATTACH"语句


下面介绍使用"FOR ATTACH"语句的用法,以克服在使用sp_attach_db和sp_attach_single_file_db时要面临的限制.


1.创建实例数据库




  1. USE master  

  2. GO  

  3. CREATE DATABASE Test ON  

  4. (NAME = 'Test', FILENAME = 'D:/Test.mdf', SIZE = 3072KB , FILEGROWTH = 1024KB )  

  5. LOG ON  

  6. (NAME = 'Test_log', FILENAME = 'D:/Test_log.ldf', SIZE = 1024KB , FILEGROWTH = 10%)  

  7. GO  


2.使用sp_detach_db分离该数据库并使用sp_attach_db将它重新附加




  1. USE master  

  2. GO  

  3. -- 分离数据库  

  4. EXEC sp_detach_db 'Test'  

  5. GO  

  6. -- 附加数据库  

  7. EXEC sp_attach_db 'Test''D:/Test.mdf''D:/Test_log.ldf'  

  8. GO  


3.使用"CREATE DATABASE database_name FOR ATTACH"语句附加数据库




  1. USE master  

  2. GO  

  3. -- 分离数据库  

  4. EXEC sp_detach_db 'Test'  

  5. GO  

  6. -- 使用"CREATE DATABASE database_name FOR ATTACH"附加数据库  

  7. CREATE DATABASE Test ON  

  8. (FILENAME = 'D:/Test.mdf'),  

  9. (FILENAME = 'D:/Test_log.ldf')  

  10. FOR ATTACH  

  11. GO  


4.分离数据库并删除日志(.ldf)文件




  1. USE master  

  2. GO  

  3. -- 分离数据库  

  4. EXEC sp_detach_db 'Test'  

  5. GO  

  6. -- 删除日志文件  

  7. EXEC master..xp_cmdshell 'del "D:/Test_log.ldf"'  

  8. GO  

  9. -- 如果cmdshell功能不可使用则使用下面语句激活cmdshell功能  

  10. USE master  

  11. GO  

  12. sp_configure 'show advanced options', 1  

  13. GO  

  14. RECONFIGURE WITH OVERRIDE  

  15. GO  

  16. SP_CONFIGURE 'xp_cmdshell', 1  

  17. RECONFIGURE WITH OVERRIDE  

  18. GO  


5.使用sp_attach_single_file_db附加.mdf文件




  1. USE master  

  2. GO  

  3. EXEC sp_attach_single_file_db 'Test''D:/Test.mdf'  

  4. GO  


6.删除日志文件,使用"CREATE DATABASE database_name FOR ATTACH_REBUILD_LOG"附加数据库




  1. USE master  

  2. GO  

  3. EXEC sp_detach_db 'Test'  

  4. GO  

  5. -- 删除日志文件  

  6. EXEC master..xp_cmdshell 'del "D:/Test_log.ldf"'  

  7. GO  

  8. -- 使用"CREATE DATABASE database_name FOR ATTACH_REBUILD_LOG"附加数据库  

  9. CREATE DATABASE Test ON  

  10. (FILENAME = 'D:/Test.mdf')  

  11. FOR ATTACH_REBUILD_LOG  

  12. GO  

该文章在 2013/4/2 22:15:40 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved