Backup--完整备份会打破现有的日志备份链么?
--问题描述:
--对数据库有一个周期性数据库备份和事务日志备份的维护计划,在维护计划外有工作人员对数据库进行完整备份,该备份会打乱现有的日志备份链么?
--==========================================================
--创建数据库
CREATE DATABASE BackupTestDB
GO
USE BackupTestDB
GO
--创建测试表
CREATE TABLE TB1
(
ID INT IDENTITY( 1,1 ) PRIMARY KEY,
ActionDesc NVARCHAR (200),
ActionTime DATETIME DEFAULT GETDATE()
)
--第一次完整备份
BACKUP DATABASE BackupTestDB TO DISK='G:\DBBackup\F1.BAK'
GO
--第一次完整备份后记录
INSERT INTO TB1( ActionDesc) SELECT N' 第一次完整备份后 '
GO
--第一次日志备份
BACKUP LOG BackupTestDB TO DISK ='G:\DBBackup\L1.BAK'
--第一次日志备份后记录
INSERT INTO TB1( ActionDesc) SELECT N' 第一次日志备份后 '
GO
--第二次完整备份
BACKUP DATABASE BackupTestDB TO DISK='G:\DBBackup\F2.BAK'
GO
--第二次完整备份后记录
INSERT INTO TB1( ActionDesc) SELECT N' 第二次完整备份后 '
GO
--第二次日志备份
BACKUP LOG BackupTestDB TO DISK ='G:\DBBackup\L2.BAK'
--第二次日志备份后记录
INSERT INTO TB1( ActionDesc) SELECT N' 第二次日志备份后 '
GO
--==========================================================
--还原方式
USE master
GO
--使用第一次完整备份恢复
RESTORE DATABASE BackupTestDB FROM DISK='G:\DBBackup\F1.BAK'
WITH NORECOVERY ,REPLACE
GO
--使用第一次日志备份恢复
RESTORE DATABASE BackupTestDB FROM DISK='G:\DBBackup\L1.BAK'
WITH NORECOVERY ,REPLACE
GO
--使用第二次日志备份恢复
RESTORE DATABASE BackupTestDB FROM DISK='G:\DBBackup\L2.BAK'
WITH RECOVERY ,REPLACE
GO
USE BackupTestDB
GO
SELECT * FROM TB1
还原方式
USE master
GO
--使用第二次完整备份恢复
RESTORE DATABASE BackupTestDB
FROM DISK ='G:\DBBackup\F2.BAK'
WITH NORECOVERY ,REPLACE
GO
--使用第二次日志备份恢复
RESTORE DATABASE BackupTestDB
FROM DISK ='G:\DBBackup\L2.BAK'
WITH RECOVERY ,REPLACE
GO
USE BackupTestDB
GO
SELECT * FROM TB1
--案例:
--有数据库DB1 ,该数据库由于长时间未做日志备份,导致数据文件为 GB,而日志文件有GB,为截断日志,工作人员对数据库进行完整备份 +日志备份,结果发现日志备份耗费大量时间,且生成的日志备份文件较大。
--解释:在数据库完成第一次完整备份后,第一次日志备份会以第一次完整备份为起始点开始备份日志,而后续的日志备份会以最近一次日志备份结束点为起始点开始备份,而不考虑最近一次完整备份。
--如果确认当前数据无问题同是想快速收缩日志文件,可以修改数据库恢复模式为简单模式,然后收缩日志文件,再进行完整备份 +事务日志备份
--建议:
--在DBA 维护过程中,会在维护计划外对数据库进行备份,备份应考虑当前维护计划,应该将备份文件存放到维护计划使用的目录下,尤其是对日志进行备份,如果不希望截断日志,可以使用 COPY_ONLY
Backup--完整备份会打破现有的日志备份链么?的更多相关文章
- MySQL完全备份脚本:数据+二进制日志+备份日志
一. 脚本须知 1.mysql数据文件和二进制日志文件最好保存在不同的分区或存储设备上 2.备份完成后注意修改数据的权限以防止泄露重要信息,哪些主机哪些用户可以用来恢复 3. 查看导出的2进制日志文件 ...
- sql server 完整备份、差异备份、事务日志备份
一. 理解: 完整备份为基础, 完整备份可以实物回滚还原,但是由于完整备份文件过大,对硬盘空间比较浪费这是就需要差异备份 或者 事务日志备份. 差异备份还原时,只能还原到备份的那个点, 日志备份还原时 ...
- 【SQL Server备份恢复】维护计划实现备份:每周数据库完整备份、每天差异备份、每小时日志备份
在数据库管理中,数据库备份是非常重要的. 通过维护计划向导,可以很方便的完成数据库备份. 下面的例子说明了如何实现数据库的备份,具体的备份策略是:每周日一次完整备份.每天差异备份(除周日外).每小时日 ...
- sqlserver全备份,差异备份和日志备份
差异备份是以上一个全备为基点,这个期间所有差异数据的备份. 日志备份是基于前一个全备+日志备份为基点,这个期间的事务日志的备份.(日志备份用于确保还原数据库到某个时间点) 在利用全备+日志备份 ...
- SQL SERVER完整、差异和事务日志备份及还原(脚本和GUI实现) [原创]
一.完整备份.差异备份和事务日志备份的脚本 --完整备份数据库 BACKUP DATABASE Test_Bak TO DISK = 'E:\20150609_75\bak\Test_bak_full ...
- SQL SERVER BUG--Alwayson日志备份报错
数据库版本 SQL SERVER 2012 企业版,版本号:11.0.5582.0 问题场景: 数据库配置Alwayson环境,同机房2节点同步自动切换+跨机房异步,在异步机房中选取同一节点做完整备份 ...
- mysql导出csv/sql/newTable/txt的方法,mysql的导入txt/sql方法...mysql备份恢复mysqlhotcopy、二进制日志binlog、直接备份文件、备份策略、灾难恢复.....................................................
mysql备份表结构和数据 方法一. Create table new_table_nam备份到新表:MYSQL不支持: Select * Into new_table_name from old_t ...
- 日志备份和差异备份还原中的常见问题示例(转自&邹建)
--创建测试 CREATE DATABASE db GO --正常备份 BACKUP DATABASE db TO DISK='c:\1.bak' WITH FORMAT BACKUP LOG ...
- SQL Server数据恢复——日志备份
太坑了,我把数据给删了 “大坑啊,数据被我误删了.”从事数据库相关工作的过程中,我想应该很多人会有过和我一样的遭遇吧?尤其是在进行update或者delete操作的时候,忘记了where条件.这些毁灭 ...
随机推荐
- Python网络编程与并发编程
网络编程基础 黏包 , 并发 计算机网络的发展及基础网络概念 Python 中的进程与 锁 Python IO 多路复用 \协程
- DBCA Does Not Display ASM Disk Groups In 11.2
DBCA Does Not Display ASM Disk Groups In 11.2 https://oraclehowto.wordpress.com/2011/08/15/dbca-does ...
- Spring 中的 LocalSessionFactoryBean和LocalContainerEntityManagerFactoryBean
Spring和Hibernate整合的时候我们经常会有如下的配置代码 1,非JPA支持的配置 <!-- 配置 Hibernate 的 SessionFactory 实例: 通过 Spring 提 ...
- flutter android keystore
keytool -genkey -v -keystore E:/key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias key k ...
- PHP - 引用计数
引用计数以及是否是引用变量,一个神奇的函数,查看当前引用计数: <?php xdebug_debug_zval('a'); 以上例程会输出: a: (refcount=1, is_ref=0)= ...
- kubernetes configmap
ConfigMaps允许您将配置工件与image内容分离,以保持容器化应用程序的便携性. 本页面提供了一系列使用示例,演示如何使用ConfigMaps中存储的数据创建ConfigMaps和配置Pod. ...
- FreeSWITCH 客户端fs_cli连接设置(acl)
FreeSWITCH 默认配置只能 在本机连接, 要从 外面连接, 就要配置: acl.conf.xml::network-lists/list event_socket.conf.xml::appl ...
- iOS倒计时
现在开发基本上都有发送验证码,倒计时,下面说一种 #import <UIKit/UIKit.h> @interface UIButton (CountDown) -(void)startT ...
- XSS的原理分析与解剖(第二篇)[转]
0×01 前言: 上节(http://www.freebuf.com/articles/web/40520.html)已经说明了xss的原理及不同环境的构造方法.本期来说说XSS的分类及挖掘方法. 当 ...
- [C++] c pointer
the nature of pointer const keyword const int* p int const *p int* const p int const a const int a ...