久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

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

168次閱讀
沒有評論

共計 2162 個字符,預(yù)計需要花費 6 分鐘才能閱讀完成。

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

什么是快照

數(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é)果:

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

use Snapshot_Test_shot; go SELECT * FROM dbo.test;

結(jié)果:

以上語句執(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é)果:

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

use Snapshot_Test_shot; go SELECT * FROM dbo.test;

結(jié)果:

依舊沒有數(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é)果:

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

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

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

DROP DATABASE Snapshot_Test_shot

結(jié)果:

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

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-08-03發(fā)表,共計2162字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 桐庐县| 伊春市| 江口县| 南岸区| 二连浩特市| 筠连县| 玛纳斯县| 怀远县| 光山县| 旅游| 综艺| 中宁县| 黑水县| 应城市| 泗阳县| 木里| 桂平市| 林州市| 行唐县| 弥渡县| 阳春市| 穆棱市| 巫溪县| 岢岚县| 嘉黎县| 和政县| 金坛市| 四川省| 永寿县| 甘南县| 仙桃市| 会宁县| 通河县| 济阳县| 汨罗市| 高要市| 钦州市| 大丰市| 阿尔山市| 永嘉县| 商洛市|