数据库的恢复模式

Jun 07, 2016 pm 03:00 PM
コンテンツ 始める 回復する データベース モデル

---恢复内容开始--- 数据库的恢复模式是数据库遭到破坏时还原数据库中数据的数据存储方式,它与可用性、性能、磁盘空间等因素相关。每一种恢复模式都按照不同的方式维护数据库的数据和日志。系统提供了3种数据库的恢复模式: 1、完整恢复模式 2、大容量日志

---恢复内容开始---

数据库的恢复模式是数据库遭到破坏时还原数据库中数据的数据存储方式,它与可用性、性能、磁盘空间等因素相关。每一种恢复模式都按照不同的方式维护数据库的数据和日志。系统提供了3种数据库的恢复模式:

1、完整恢复模式

2、大容量日志记录的恢复模式

3、简单恢复模式

    完整恢复模式是最高等级的数据库恢复模式。在完整恢复模式中,对数据库的所有操作都记录在数据库的事务日志中。即使那些大容量数据库操作和创建索引的操作,也就记录在数据库的事务日志中。当数据库遭到破坏之后,可以使用该数据库的事务日志迅速还原数据库。

   在完整恢复模式中,由于事务日志记录了数据库的所有变化,所以可以使用事务日志将数据库还原到任意的时刻点。但是,这种恢复模式耗费大量的磁盘空间。除非是那种事务日志非常重要的数据库备份策略,否则一般不建议使用这种恢复模式。

   就想完整恢复模式一样,大容量日志记录的恢复模式也使用数据库备份和日志备份还原数据库。但是,在使用了大容量日志记录的恢复模式的数据库中,其事务日志耗费了的磁盘空间远远小于使用完整恢复模式的数据库的事务日志。在大容量日志记录的恢复模式中,Check Index、bulk insert、BCP、Select Into等操作不记录在事务日志中。

   对于那些规模比较小的数据库或数据不经常改变的数据库来说,可以使用简单恢复模式。当使用简单恢复模式时,可以通过执行完全数据库备份和增量数据库备份来还原数据库,数据库只能还原到执行备份操作的时刻点。执行备份操作之后的所有的数据修改都丢失并且需要重建。这种模式的特点是数据库没有事务日志。这种模型的好处是耗费比较少的磁盘空间,恢复模式最简单。

举个例子:

假设出问题的数据库为A, 新恢复后的数据库为B
1.前提:A数据库的恢复模式必须为:完整。
2.备份A数据库的日志,假设文件名为log.bak
3.使用A数据库的最近的完整备份,使用 WITH NORECOVERY 的方式,恢复为B数据库
4.使用恢复日志的方式,指定还原的时间点(T),将Log.bak文件还原到B数据库,完成后,B数据库的内容即是T时间之前的完整数据。

 

以下为测试语句建A数据库

--<span>创建A数据库 
CREATE   DATABASE   A 
GO 

</span>--<span>对A数据库进行备份 
BACKUP   DATABASE   A   TO   DISK</span>= <span>'</span><span>c:\A.bak </span><span>'</span><span>   WITH   FORMAT 
GO 

</span>--<span>创建测试表 
CREATE   TABLE   A.dbo.TB_test(ID   </span><span>int</span><span>) 

GO
</span>--<span>插入数据
Insert Into A.dbo.TB_test(ID)
</span><span>select</span> <span>1</span><span>

GO

</span>--<span>延时1秒钟,再进行后面的操作
</span>--<span>(这是由于SQL   Server的时间精度最大为百分之三秒,不延时的话,可能会导致还原到时间点的操作失败) 
WAITFOR   DELAY   </span><span>'</span><span>00:00:01 </span><span>'</span><span> 
GO 

</span>--<span>假设我们现在误操作删除了   A.dbo.TB_test   这个表 
DROP   TABLE   A.dbo.TB_test 

</span>--<span>为了测试还原时间点,先记录操作的时间点
SELECT   dt</span>=<span>GETDATE()   INTO   #T 
GO 

</span>--<span>在删除操作后,发现不应该删除表    TB_test 

</span>--<span>下面演示了如何恢复这个误删除的表    TB_test,以及数据行

</span>--<span>为了避免覆盖A数据库,恢复时,生成到B数据库

GO
</span>--<span>首先,备份A数据库的事务日志(使用事务日志才能还原到指定的时间点) 
BACKUP   LOG   A   TO   DISK</span>= <span>'</span><span>c:\A_log.bak </span><span>'</span><span>   WITH   FORMAT 
GO 

</span>--<span>接下来,我们要先还原完全备份(还原日志必须在还原完全备份的基础上进行),生成数据库B
RESTORE   DATABASE   B   FROM   DISK</span>= <span>'</span><span>c:\A.bak </span><span>'</span><span> 
WITH  FILE </span>= <span>1</span>,  MOVE N<span>'</span><span>A</span><span>'</span> TO N<span>'</span><span>C:\B.mdf</span><span>'</span><span>,  
                MOVE N</span><span>'</span><span>A_log</span><span>'</span> TO N<span>'</span><span>C:\B.ldf</span><span>'</span><span>,  NORECOVERY,    REPLACE  
GO 

</span>--<span>将事务日志还原到删除操作前(这里的时间对应上面的删除时间,并比删除时间略早 
DECLARE   @dt   datetime 
SELECT   @dt</span>=DATEADD(ms,-<span>20</span>,dt)   FROM   #T     --<span>获取比表被删除的时间略早的时间 
RESTORE   LOG   B   FROM   DISK</span>= <span>'</span><span>c:\A_log.bak </span><span>'</span>   WITH   RECOVERY,STOPAT=<span>@dt 

GO 

</span>--<span>查询一下,看表是否恢复 
SELECT   </span>*<span>   FROM   B.dbo.TB_test 

</span>--<span>最后删除我们做的测试环境 
DROP   DATABASE   A 
DROP   DATABASE   B
DROP   TABLE   #T</span>
ログイン後にコピー

 

---恢复内容结束---

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

iPhoneでサイレントモードが機能しない:修正 iPhoneでサイレントモードが機能しない:修正 Apr 24, 2024 pm 04:50 PM

おやすみモードで電話に応答することさえ、非常に煩わしい経験になる可能性があります。名前が示すように、おやすみモードでは、すべての着信通知と電子メール、メッセージなどからの警告がオフになります。これらのソリューション セットに従って問題を修正できます。解決策 1 – フォーカス モードを有効にする 携帯電話でフォーカス モードを有効にします。ステップ 1 – 上から下にスワイプしてコントロール センターにアクセスします。ステップ 2 – 次に、携​​帯電話の「フォーカスモード」を有効にします。フォーカス モードでは、電話機のサイレント モードが有効になります。携帯電話に着信通知が表示されることはありません。解決策 2 – フォーカス モード設定を変更する フォーカス モード設定に問題がある場合は、修正する必要があります。ステップ 1 – iPhone の設定ウィンドウを開きます。ステップ 2 – 次に、フォーカス モード設定をオンにします

Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Mar 27, 2024 pm 09:39 PM

Go 言語は、効率的かつ簡潔で習得が容易なプログラミング言語であり、同時プログラミングやネットワーク プログラミングに優れているため、開発者に好まれています。実際の開発ではデータベースの操作が欠かせませんが、今回はGo言語を使ってデータベースの追加・削除・変更・クエリ操作を実装する方法を紹介します。 Go 言語では、データベースを操作するために通常、よく使用される SQL パッケージや gorm などのサードパーティ ライブラリを使用します。ここでは SQL パッケージを例として、データベースの追加、削除、変更、クエリ操作を実装する方法を紹介します。 MySQL データベースを使用していると仮定します。

小紅書で削除されたコメントを復元するにはどうすればよいですか?削除されたコメントに関するヒントはありますか? 小紅書で削除されたコメントを復元するにはどうすればよいですか?削除されたコメントに関するヒントはありますか? Mar 27, 2024 am 11:56 AM

Xiaohonshu は、ユーザーがショッピング体験や生活の詳細などを共有できる人気のソーシャル e コマース プラットフォームです。使用中にコメントが削除される場合があります。それでは、Xiaohongshuで削除されたコメントを復元するにはどうすればよいですか? 1.小紅書で削除されたコメントを復元するにはどうすればよいですか?コメントが誤って削除されたことが判明した場合、ユーザーは公式小紅書チームがコメントを復元するのを待つことを選択できます。この場合、しばらくすると公式チームがコメントを自動的に処理して再開する可能性があるため、辛抱強く待つことが最善です。コメントが削除されていることがわかった場合は、同様のコンテンツを再公開することを検討してください。ただし、再投稿する場合は、再度削除されないよう、コンテンツが小紅書コミュニティ ガイドラインに準拠していることを確認してください。 3. Xiaohonshu カスタマーサービスにご連絡ください: コメントが間違っていると思われる場合

Hibernate はポリモーフィック マッピングをどのように実装しますか? Hibernate はポリモーフィック マッピングをどのように実装しますか? Apr 17, 2024 pm 12:09 PM

Hibernate ポリモーフィック マッピングは、継承されたクラスをデータベースにマップでき、次のマッピング タイプを提供します。 join-subclass: 親クラスのすべての列を含む、サブクラス用の別個のテーブルを作成します。 table-per-class: サブクラス固有の列のみを含む、サブクラス用の別個のテーブルを作成します。 Union-subclass: join-subclass と似ていますが、親クラス テーブルがすべてのサブクラス列を結合します。

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます Jul 18, 2024 am 05:48 AM

Apple の最新リリースの iOS18、iPadOS18、および macOS Sequoia システムでは、さまざまな理由で紛失または破損した写真やビデオをユーザーが簡単に回復できるように設計された重要な機能が写真アプリケーションに追加されました。この新機能では、写真アプリのツール セクションに「Recovered」というアルバムが導入され、ユーザーがデバイス上に写真ライブラリに含まれていない写真やビデオがある場合に自動的に表示されます。 「Recovered」アルバムの登場により、データベースの破損、カメラ アプリケーションが写真ライブラリに正しく保存されない、または写真ライブラリを管理するサードパーティ アプリケーションによって失われた写真やビデオに対する解決策が提供されます。ユーザーはいくつかの簡単な手順を実行するだけで済みます

HTML がデータベースを読み取る方法の詳細な分析 HTML がデータベースを読み取る方法の詳細な分析 Apr 09, 2024 pm 12:36 PM

HTML はデータベースを直接読み取ることはできませんが、JavaScript と AJAX を通じて実現できます。この手順には、データベース接続の確立、クエリの送信、応答の処理、ページの更新が含まれます。この記事では、JavaScript、AJAX、および PHP を使用して MySQL データベースからデータを読み取る実践的な例を示し、クエリ結果を HTML ページに動的に表示する方法を示します。この例では、XMLHttpRequest を使用してデータベース接続を確立し、クエリを送信して応答を処理することで、ページ要素にデータを埋め込み、データベースを読み取る HTML の機能を実現します。

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル Jun 04, 2024 pm 01:42 PM

MySQLi を使用して PHP でデータベース接続を確立する方法: MySQLi 拡張機能を含める (require_once) 接続関数を作成する (functionconnect_to_db) 接続関数を呼び出す ($conn=connect_to_db()) クエリを実行する ($result=$conn->query()) 閉じる接続 ( $conn->close())

PHP でデータベース接続エラーを処理する方法 PHP でデータベース接続エラーを処理する方法 Jun 05, 2024 pm 02:16 PM

PHP でデータベース接続エラーを処理するには、次の手順を使用できます。 mysqli_connect_errno() を使用してエラー コードを取得します。 mysqli_connect_error() を使用してエラー メッセージを取得します。これらのエラー メッセージをキャプチャしてログに記録することで、データベース接続の問題を簡単に特定して解決でき、アプリケーションをスムーズに実行できるようになります。

See all articles