SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

十載的潼關(guān)網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整潼關(guān)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)從事“潼關(guān)網(wǎng)站設(shè)計”,“潼關(guān)網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。

什么是快照

數(shù)據(jù)庫快照是sql server 2005的一個新功能。MSDN上對它的定義是:

數(shù)據(jù)庫快照是數(shù)據(jù)庫(稱為“源數(shù)據(jù)庫”)的只讀靜態(tài)視圖。在創(chuàng)建時,每個數(shù)據(jù)庫快照在事務(wù)上都與源數(shù)據(jù)庫一致。在創(chuàng)建數(shù)據(jù)庫快照時,源數(shù)據(jù)庫通常會有打開的事務(wù)。在快照可以使用之前,打開的事務(wù)會回滾以使數(shù)據(jù)庫快照在事務(wù)上取得一致。

客戶端可以查詢數(shù)據(jù)庫快照,這對于基于創(chuàng)建快照時的數(shù)據(jù)編寫報表是很有用的。而且,如果以后源數(shù)據(jù)庫損壞了,便可以將源數(shù)據(jù)庫恢復(fù)到它在創(chuàng)建快照時的狀態(tài)。

下面我們實踐一下數(shù)據(jù)庫快照的創(chuàng)建和使用。

創(chuàng)建示例數(shù)據(jù)庫

Use MASTER; GO CREATE DATABASE [Snapshot_Test] ON  PRIMARY ( NAME = N'Snapshot_Test', --數(shù)據(jù)庫名稱 FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\Snapshot_Test.mdf', --數(shù)據(jù)文件存放位置及數(shù)據(jù)文件名稱 SIZE = 3072KB , --初始容量 MAXSIZE = UNLIMITED, --最大容量 FILEGROWTH = 1024KB --增長容量 ) LOG ON ( NAME = N'Snapshot_Test_log', FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\Snapshot_Test_log.ldf' , SIZE = 504KB , MAXSIZE = UNLIMITED, FILEGROWTH = 10%) COLLATE Chinese_PRC_CI_AS GO EXEC dbo.sp_dbcmptlevel @dbname=N'Snapshot_Test', @new_cmptlevel=130 GO USE [Snapshot_Test] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[test](  [id] [int] NOT NULL,  [name] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NOT NULL ) ON [PRIMARY] GO

(提示:可以左右滑動代碼)

在創(chuàng)建完數(shù)據(jù)庫之后,我們馬上創(chuàng)建一個快照,創(chuàng)建快照使用的也是CREATE DATABASE語句,如下:

創(chuàng)建數(shù)據(jù)庫快照

create database Snapshot_Test_shot ON (    --是源數(shù)據(jù)庫的邏輯名    Name = Snapshot_Test,    --快照文件地址    FileName = 'D:\SqlData\Snapshot_Test_shot.ss' ) AS SNAPSHOT OF Snapshot_Test;

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

現(xiàn)在的快照應(yīng)該和我們新建的數(shù)據(jù)庫一摸一樣,可以通過sql server的對象瀏覽器查看數(shù)據(jù)庫快照,我們可以通過USE [快照庫名]來查詢數(shù)據(jù)庫快照

use Snapshot_Test_shot; go SELECT * FROM dbo.test;

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

以上語句執(zhí)行后dbo.test中沒有任何數(shù)據(jù),下一步我們往源數(shù)據(jù)庫表中插入幾條數(shù)據(jù)

use snapshot_Test; go INSERT INTO TEST (id,name)values(1,'hello 1'); INSERT INTO TEST (id,name)values(2,'hello 2'); INSERT INTO TEST (id,name)values(3,'hello 3'); INSERT INTO TEST (id,name)values(4,'hello 4'); GO SELECT * FROM dbo.test;

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

我們再次查詢快照數(shù)據(jù)庫中的數(shù)據(jù)

use Snapshot_Test_shot; go SELECT * FROM dbo.test;

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

依舊沒有數(shù)據(jù),那是因為快照一旦創(chuàng)建就不能往里面寫數(shù)據(jù)了,是只讀文件。

使用快照恢復(fù)數(shù)據(jù)庫

從數(shù)據(jù)庫快照恢復(fù)數(shù)據(jù)庫

use master; GO RESTORE DATABASE Snapshot_Test from DATABASE_SNAPSHOT = 'Snapshot_Test_shot';

恢復(fù)后,剛插入的數(shù)據(jù)就沒有了,我們可以查詢一下。

use Snapshot_Test; SELECT * FROM dbo.test

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

由此可以證明,快照將數(shù)據(jù)庫恢復(fù)到創(chuàng)建快照的那一刻了。

刪除數(shù)據(jù)庫快照

和刪除數(shù)據(jù)庫的語法一樣

DROP DATABASE Snapshot_Test_shot

結(jié)果:

SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功

上述就是小編為大家分享的SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前題目:SQL中怎么實現(xiàn)數(shù)據(jù)恢復(fù)功
文章源于:http://bm7419.com/article16/gejddg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、搜索引擎優(yōu)化、全網(wǎng)營銷推廣、網(wǎng)站內(nèi)鏈網(wǎng)站建設(shè)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)