SQLServer中如何进行数据库单个和批量备份
Admin 2022-08-05 群英技术资讯 872 次浏览
前言最近公司服务器到期,需要进行数据迁移,而数据库属于多而繁琐,通过图形化界面一个一个备份所需时间成本很大,所以想着写一个sql脚本来执行。
图形化界面备份这里就不展示了,可以自行百度,下面直接贴代码
USE MASTER IF EXISTS ( SELECT * FROM sysobjects WHERE id = OBJECT_ID(N'[BackupDataProc]') AND OBJECTPROPERTY(id, N'IsProcedure') = 1 ) DROP PROCEDURE BackupDataProc go create proc BackupDataProc @FullName Varchar(200)--入参(数据库名) as begin Declare @FileFlag varchar(50) Set @FileFlag='C:\myfile\database\'+@FullName+'.bak'--备份到哪个路径(C:\myfile\database\)根据自己需求来定 BackUp DataBase @FullName To Disk=@FileFlag with init--核心代码 end exec BackupDataProc xxx
执行成功后便会生成一个.bak文件到指定文件夹中,如图
USE MASTER if exists(SELECT * FROM sys.types WHERE name = 'AllDatabasesNameType') drop type AllDatabasesNameType go create type AllDatabasesNameType as table--自定义表类型用于存储数据库名称 ( rowNum int , name nvarchar(60), filename nvarchar(300) ) go IF EXISTS ( SELECT * FROM sysobjects WHERE id = OBJECT_ID(N'[BachBackupDataProc]') AND OBJECTPROPERTY(id, N'IsProcedure') = 1 ) DROP PROCEDURE BachBackupDataProc go create proc BachBackupDataProc @filePath nvarchar(300)--入参,备份时的目标路径 as begin Declare @AllDatabasesName as AllDatabasesNameType --用于存储系统中的数据库名 Declare @i int --循环变量 insert into @AllDatabasesName(name,filename,rowNum) select name,filename,ROW_NUMBER() over(order by name) as rowNum from sysdatabases where name not in('master','tempdb','model','msdb') --赋值 set @i =1 --循环备份数据库 while @i <= (select COUNT(*) from @AllDatabasesName) begin Declare @FileFlag varchar(500) Declare @FullName varchar(50) Select @FullName =name from @AllDatabasesName where rowNum = @i Set @FileFlag=@filePath+@FullName+'.bak' BackUp DataBase @FullName To Disk=@FileFlag with init set @i = @i + 1 end end exec BachBackupDataProc 'C:\myfile\database\'
执行结果效果如下图:
IF EXISTS ( SELECT * FROM sysobjects WHERE id = OBJECT_ID(N'[ReductionProc]') AND OBJECTPROPERTY(id, N'IsProcedure') = 1 ) DROP PROCEDURE ReductionProc go create proc ReductionProc @Name nvarchar(200)--入参 数据库名称 as begin Declare @DiskName nvarchar(500) Declare @FileLogName nvarchar(100) Declare @FileFlagData nvarchar(500) Declare @FileFlagLog nvarchar(500) Set @FileLogName = @Name + '_log' Set @DiskName = 'C:\myfile\database\'+@Name+'.bak' ---(源)备份文件路径 Set @FileFlagData='C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\'+@Name+'.mdf'---(目标)指定数据文件路径 Set @FileFlagLog='C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\'+@FileLogName+'.ldf'---目标)指定日志文件路径 RESTORE DATABASE @Name --为待还原库名 FROM DISK = @DiskName ---备份文件名 WITH MOVE @Name TO @FileFlagData, ---指定数据文件路径 MOVE @FileLogName TO @FileFlagLog, ---指定日志文件路径 STATS = 10, REPLACE end go exec ReductionProc xxx
执行后便能还原库(我是拿这三个库做测试,截的图可能没什么变化,你们可以尝试下)
当然还原的过程可能会遇到一些问题,比如:
1.版本不一样
2.SQL Sql 逻辑文件'XXXXX ' 不是数据库'YYY'的一部分。请使用 RESTORE FILELISTONLY 来列出逻辑文件名。
版本的话我试过了,高版本可以向下兼容,但是低版本不能向上兼容,可以统一版本来解决(如有更好的解决方案欢迎打扰)
第二个问题呢就是脚本中‘MOVE' 他只能跟逻辑名,而有些数据库的逻辑名并不是数据库名称,所以需要替换一下,
下面是查询数据库逻辑名的sql语句:
USE MASTER restore filelistonly from disk='D:\sql201database\Sence.bak'--根据自己的需求要变更路径
如图,
对于这些逻辑名与数据库名称不一致的情况可以单独拿出来重新执行一下即可:
USE MASTER --这里注意要使用MASTER,以免出现待还原库被占用的情况 RESTORE DATABASE Sence --为待还原库名 FROM DISK = 'D:\sql201database\Sence.bak' ---备份文件名 WITH MOVE 'Sence_Guangxi' TO 'D:\Database\Data\Sence.mdf', ---指定数据文件路径 MOVE 'Sence_Guangxi_log' TO 'D:\Database\Data\Sence_log.ldf', ---指定日志文件路径 STATS = 10, REPLACE GO
数据是无价的,对数据库操作时备份是必须的。
数据是无价的,对数据库操作时备份是必须的。
数据是无价的,对数据库操作时备份是必须的。(重要的事说三遍)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
B/S架构中最经典的话题无非于三层架构,可以大概分为数据层,业务逻辑层和表示层,而数据层的作用一般都是和数据库交互,例如查询记录。我们经常是写好查询SQL,然后调用程序执行SQL。但是它内部的工作流程是怎样的呢?先做哪一步,然后做哪一步等,我想还有大部分朋友和我一样都不一定清楚。
本文主要讲解索引性能优化,着重对Bookmark Lookup、RID Lookup、Key Lookup三者进行移除的实现进行解析,以此来提高查询性能。希望对大家有所帮助
SQL Server调用存储过程的方式有什么?对SQL Server调用存储过程下文给大家介绍了SQL SERVER中调用不带输出参数的存储过程和SQL SERVER中调用带输出参数的存储过程,接下来我们详细了解看看。
多表查询就是在一条查询语句中,从多张表里一起取出所需的数据,如果要想进行多表查询,下面这篇文章主要给大家介绍了关于SQL语句如何实现超简单的多表查询的相关资料,需要的朋友可以参考下
sql数据库怎样实现跨库访问?有些需求需要我们一个数据库访问另一个数据库,或者一台服务器访问另一台服务器的数据库,很多新手不了解要怎样做sql跨库访问,下面小编就给大家介绍一下实现方法。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008