mssqlServer 数据库备份和还原认识和总结(二)
本文将针对上文继续进行数据备份和还原讲解,主要讲解备份和还原的一些关键选项。
数据库备份选项
备份数据库时,有几个备份选项需要了解一下,覆盖介质、事务日志等。谈到覆盖介质时,必须先对这个概念有所了解,不然无从谈起。
● 介质集 (media set):备份介质(磁带或磁盘文件)的有序集合,使用固定类型和数量的备份设备向其写入了一个或多个备份操作。介质集所使用的备份设备的数量决定了介质集中的介质簇的数量。 例如,如果介质集使用两个非镜像备份设备,则该介质集包含两个介质簇。通常,创建介质集后,后续备份操作将依次向介质集追加其备份集。
● 介质簇 (media family):在介质集中的单个非镜像设备或一组镜像设备上创建的备份。
● 备份集 (backup set):成功的备份操作将向介质集中添加一个备份集。
大致了解以上概念后,回到备份选项上来:
◆ 备份到现有介质集-追加到现有备份集
如果要将数据库备份到磁盘上,那么选择磁盘后(可以选择一个或多个磁盘驱动器,也可选择磁带机设备,在此以磁盘驱动器为例),如果保持默认【备份到现有介质集-追加到现有备份集】SQL Server将自动创建一个介质集(备份介质(磁盘文件或磁带)的每个卷都包含介质标头,介质标头是在第一次使用磁带(或磁盘)执行备份操作时创建的,它将包含介质的名称、介质集的唯一标识号、介质簇的唯一标识号等等),然后再将备份集添加到介质集中。例如上篇文章中首次完整备份,SQL Server将自动创建一个介质集,并将备份集添加到介质集中,接着再备份事务日志文件,此事务日志文件备份集将被追加到现有备份集,最终备份文件我们看到的只是一个备份文件MyTest.bak,但还原时选择此文件后,要还原的备份集列表将显示先后备份的备份集,如完整备份集、第一次事务日志备份集、第二次事务日志备份集等。
◆ 备份到现有介质集-覆盖所有现有备份集
此选项将覆盖介质上的所有备份集并保留介质标头(如果有)。 如果没有介质标头,则创建一个标头。覆盖备份时,保留现有的所有介质标头,同时将新的备份创建为备份设备中的第一个备份。
存在下列任一条件时不覆盖备份介质:
● 介质上的现有备份尚未过期。 (如果指定 SKIP,则不检查过期。)
过期日期将指定备份过期的日期,并可以由另一个备份覆盖。 创建备份时可以指定过期日期。 默认情况下,过期日期由使用 sp_configure 设置的 media retention 选项确定。
● 介质名称(如果有)与备份介质上的名称不匹配。
● 介质名称是一个描述性名称,用于方便地识别介质。
综上所述,它们的最大区别是,一个是向现在备份集追加备份集,一个是将现有备份集覆盖,即以前保存在该备份集里的信息将无法重新读取。
图1:备份时选择【追加到现有备份集】,还原时要还原的备份集里显示的,每次追加的备份集。
图2:备份时选择【覆盖所有现有备份集】,还原时要还原的备份集里显示的是已覆盖的备份集,以前追加的备份集已被覆盖。
◆ 检查介质集名称和备份集过期时间
图3:备份时输入的备份集名称和备份集过期时间,一般备份集默认会带有名称,如有必要可以修改为有意义的名称,过期时间一般保持默认永不过程。
有了上图,【检查介质集名称和备份集过期时间】里就明白该如何输入了,这个我没实验过,没有太大必要一一实验了。
◆ 备份到新介质集并清除所有现有备份集
选择此项可以清除以前的备份集,并使用新的媒体集备份数据库。
若要创建新介质集,必须格式化备份介质(一个或多个磁带或磁盘文件)。 格式化进程会对备份介质进行以下更改:
● 删除旧标头(如果存在),从而有效地删除备份介质中以前的内容。
格式化磁带设备会删除当前装入的磁带中以前所有内容。 格式化磁盘只影响您为备份操作指定的文件。
● 向每个备份设备中的备份介质(磁带或磁盘文件)写入新的介质标头。
◆ 可靠性
● 完成后验证备份。将会验证备份集是否完整以及所有卷是否都可读。
● 写入媒体前检查校验和。将会在写入备份媒体前验证校验和,如果选中此项,可能会增大工作负荷,并降低备份操作的备份吞吐量。
● 出错时继续。如果备份数据库时发生了错误,备份工作还将继续进行。
◆ 事务日志(只有在备份时备份类型选择为【事务日志】,此项才会被激活)
● 截断事务日志。选择此项会备份事务日志并将其截断,以便释放更多的日志空间,此时数据库处于在线状态。
● 备份日志尾部,并使数据库处于还原状态。选择此项会备份日志尾部并使数据库处于还原状态,该项创建尾日志备份,用于备份尚未备份的日志。当故障转移到辅助数据库或为了防止在还原操作之前丢失所做工作,该选项很有作用。选择该项后,在数据库完全还原之前,数据库无法使用。
◆ 磁带机。选择用磁带机设备备份数据库时选择此选项。
备份相关选项,MSDN有一篇文档讲得相当细,在此推荐。看完此文档后将对备份存储方面有一个深入的认识。http://msdn.microsoft.com/zh-cn/vcsharp/ms178062.aspx
数据库还原选项
◆ 【覆盖现有数据库】复选框:选中此项会覆盖所有现有数据库以及相关文件,包括已存在的同名其他数据库或文件。
◆ 【保留复制设置】复选框:选中此项会将已发布的数据库还原到创建该数据库的服务器之外的服务器时,保留复制设置。不过该项只有在选择了【回滚未提交的事务,使数据库处于可以使用的状态】单选按钮之后才可以使用。
◆ 【限制访问还原的数据库】复选框:使还原的数据库仅供 db_owner、dbcreator 或 sysadmin 的成员使用。
恢复状态:
◆ RESTORE WITH RECOVERY,通过回滚未提交的事务,使数据库处于可以使用的状态。无法还原其他事务日志。此项则让数据库在还原后进入可正常使用的状态,并自动恢复尚未完成的事务,如果本次还原是还原的最后一步操作,可以选择该项。此项为默认选项。
◆ RESTORE WITH NORECOVERY,不对数据库执行任何操作,不回滚未提交的事务。可以还原其他事务日志。此项则在还原后数据库仍然无法正常使用,也不恢复未完成的事务操作,但可继续还原事务日志备份或差异备份,让数据库能恢复到最接近目前的状态。
◆ RESTORE WITH STANDBY,使数据库处于只读模式。撤消未提交的事务,但将撤消操作保存在备用文件中,以便可使恢复效果逆转。选择此项时,备用文件选择目录将被激活。此项则在还原后进行恢复未完成事务的操作,并使数据库处于只读状态,为了可继续还原事务日志备份,还必须指定一个还原文件来存放被恢复的事务内容。
到此为止,数据库备份还原选项基本介绍完毕,有遗漏介绍的选项通过名称能直接明白。至于数据库备份还原脚本MSDN文档有语法和示例,再说也可以通过UI设置好后导出标准脚本。
以上为我对SQL Server数据库备份和还原的认识和总结,如有遗漏掉的细节或讲解错误

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

ThinkPHP6資料備份與復原:保障資料的安全性隨著網路的快速發展,資料已成為極為重要的資產。因此,資料的安全性備受關注。在Web應用開發中,資料備份與復原是確保資料安全的重要一環。在本文中,我們將介紹如何使用ThinkPHP6框架進行資料備份與恢復,以保障資料的安全性。一、資料備份資料備份是指將資料庫中的資料以某種方式複製或儲存。這樣即使在數據

透過DockerCompose、Nginx和MariaDB實現PHP應用程式的資料備份與還原隨著雲端運算和容器化技術的快速發展,越來越多的應用程式選擇使用Docker來部署和運行。在Docker生態系統中,DockerCompose是一個非常受歡迎的工具,它可以透過一個單一的設定檔來定義和管理多個容器。本文將介紹如何使用DockerCompose、Ng

在網站運作過程中,備份是一項非常重要的任務。如果網站有資料遺失或損失,備份可以為恢復網站提供便利。 PHP是一種常用的伺服器端程式語言,可以透過編寫PHP腳本來實現網站的備份功能。本文將介紹如何使用PHP實現網站備份功能。一、備份檔案的類型在備份網站的時候,需要備份資料庫和網站檔案。通常網站文件包括靜態文件、程式文件、圖片和上傳的附件等,而資料庫則包含網站的所

在進行Web開發的過程中,資料的儲存和備份無疑是非常重要的一環。面對萬一出現的資料遺失或復原需要,備份是非常必要的。對於PHP這種開源的後端語言,資料的備份同樣也有許多可選的方案,下面我們就來詳細了解PHP中的資料備份。一、資料庫備份1.1MYSQLdump工具MYSQLdump是一個備份MYSQL資料庫的命令列工具,它透過執行SQL語句將整個資料庫或

隨著資料量的不斷增大,資料庫備份的難度也越來越大。而備份不僅要求資料的完整性和一致性,還要求備份速度和備份檔案大小均能滿足實際需求。資料壓縮備份技術因此應運而生,成為資料庫備份不可或缺的技術手段之一。 MySQL是目前最受歡迎的關聯式資料庫之一,其官方提供的備份工具mysqldump並不能滿足壓縮備份的需求。因此,本文將介紹使用Linux系統上的壓縮指令ta

使用PHP和SQLite實現資料備份和復原策略備份和復原是資料庫管理中非常重要的一個環節,它可以保護我們的資料免受意外損壞或遺失的影響。本文將介紹如何使用PHP和SQLite實現資料備份和復原的策略,幫助我們更好地管理和保護資料庫中的資料。首先,我們需要建立一個使用SQLite的資料庫,並建立一些測試資料以便後續操作。以下是一個簡單的範例:<?php

如何處理C++大數據開發中的資料備份一致性問題?在C++大數據開發中,資料備份是非常重要的一環。為了確保資料備份的一致性,我們需要採取一系列的措施來解決這個問題。本文將探討如何處理C++大數據開發中的資料備份一致性問題,並提供對應的程式碼範例。使用交易進行資料備份交易是一種保證資料操作的一致性的機制。在C++中,我們可以使用資料庫中的交易概念來實現資料備份的一

如何利用Laravel實現資料備份和復原功能隨著網際網路的發展,資料備份和復原功能成為了重要的需求。在web應用中,資料備份和復原功能可以確保資料的安全性和可靠性,同時也提供了一種應對突發情況的緊急手段。 Laravel作為一種流行的PHP框架,具備強大的資料處理和資料庫操作能力,因此可以輕鬆實現資料備份和復原功能。本文將介紹如何利用Laravel實現資料備
