資料庫批量還原,資料庫批量還原系統

本文目錄一覽:

如何使用腳本批量恢復資料庫備份

蛙蛙推薦:利用WMI腳本批量恢復SQLSERVER資料庫

問題提出

蛙蛙求助:以編程的方式還原sqlserver資料庫問題

我有一個目錄下面都是sqlserver的資料庫備份文件,比如a.bak,b.bak,c.bak等,有沒有辦法一下把他們都還原到本地SQLSERVER資料庫裡面呀,過程是自動建立a,b,c這樣的資料庫,然後把a.bak恢復到a,b.bak恢復到b,依次類推,因為備份文件的原路徑和新庫的路徑不一樣,所以要有一些額外處理,誰能解決一下,因為這個目錄下有幾十個庫的備份文件呢,現在我的機器新安裝了一個SQLSERVER,要把他們全部恢復,當時沒有分離庫,所以不能直接附加.

設計方案

可以利用WMI腳本掃描存放資料庫備份文件的目錄,然後按照一定的規則生成一個恢復資料庫的T-sql腳本文件,然後用腳本執行osql程序來執行這個腳本完成資料庫恢復,這裡沒有使用過多的錯誤處理和事務的代碼,因此要人為的確定資料庫恢復的T-SQL語句盡量不要引發異常。

解決方案

一、我們先來看一下恢復資料庫的T-SQL命令,以便理解後面通過腳本來創建T-SQL的原理

USE master

GO

–如果要創建的資料庫已經存在,那麼刪除它

IF EXISTS (SELECT name FROM master.dbo.sysdatabases WHERE name = N’article’)

DROP DATABASE [article]

GO

–創建一個新資料庫,要指定新建資料庫的數據文件和日誌文件的名稱和位置,初始化大小

–增長幅度,最大值等內容

CREATE DATABASE article

ON

( NAME = N’article_dat’,

FILENAME = N’d:\sql2000\MSSQL\data\article_Data.MDF’,

SIZE = 1,

MAXSIZE = 50,

FILEGROWTH = 5 )

LOG ON

( NAME = N’article_log’,

FILENAME = N’d:\sql2000\MSSQL\data\article_Log.LDF’,

SIZE = 1MB,

MAXSIZE = 25MB,

FILEGROWTH = 5MB )

GO

–把指定的資料庫備份文件恢復到剛剛建立的資料庫里,這裡要指定資料庫備份文件的位置

–以及要恢復到的資料庫,因為備份文件來自未知的機器,備份的時候原資料庫和新資料庫

–的數據文件和日誌文件的位置不匹配,所以要用with move指令來完成強制文件移動,如果

–是通過管理器備份的資料庫文件,資料庫文件和日誌文件名分別是資料庫名跟上”_Data”或

–“_Log”,這是一個假設哦,如果不是這樣,腳本有可能會出錯

RESTORE DATABASE [article]

FROM DISK = ‘E:\windowdatabase\article.bak’

WITH

MOVE ‘article_Data’ TO ‘d:\sql2000\MSSQL\data\article_Data.MDF’,

MOVE ‘article_Log’ TO ‘d:\sql2000\MSSQL\data\article_Log.LDF’

GO

從中可以看到T-SQL的強大。

sql資料庫誤改怎樣恢復

1, 如果你有比較新的備份文件,可以將備份恢復到另外一台機器上,然後將對應表導入到當前庫;

2,如果你的日誌文件還沒有被覆蓋,將日誌文件copy出去,先備份一下,找個讀取sqlserver日誌的工具,從日誌文件中逐條記錄恢復。

oracle資料庫怎麼進行備份恢復,以及自動批量備份

Oracle資料庫備份,大致分為如下兩種:

第一種:邏輯備份:

使用EXP進行邏輯備份,在sql plus 執行:exp system/你的密碼 後按照提示命令執行即可。

第二種:物理備份

冷,熱備份的備份方法: 冷熱備份都是將資料庫文件做相應的拷貝。

冷備份:是指離線備份,即將伺服器停止掉。

熱備份:是指連機備份

使用該命令shutdown immediate停止伺服器

資料庫備份與恢復原理

一般的文件型資料庫,實際上對整個就是一個或者多個文件,所謂的備份就是把這些文件考慮到其它介質上,可能有一個打包的過程,或者刻錄到DVD的過程。這是對文件型資料庫備份和恢復的最好方法,效率最好,操作最簡單。

有的大型資料庫,它自己管理存儲空間,是分區或者磁碟,不被操作系統識別。這類資料庫一樣可以用GHOST等工具備份磁碟。

可能許多人講備份資料庫是把資料庫轉換為SQL或者文本文件。其實這是另外一個概念,叫做數據遷移,目的是把資料庫的數據移植到其它資料庫管理系統。數據遷移不適合用來做資料庫的日常備份,一般關鍵資料庫不會平凡的做數據遷移。一般資料庫系統會提供專門的數據遷移工具,當然這類工具也可能就是一系列的SQL語句,自己也能編寫。

原創文章,作者:NWZW,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/139706.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
NWZW的頭像NWZW
上一篇 2024-10-04 00:22
下一篇 2024-10-04 00:22

相關推薦

  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬碟。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • Python 常用資料庫有哪些?

    在Python編程中,資料庫是不可或缺的一部分。隨著互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的資料庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝資料庫方案

    本文將介紹在openeuler操作系統中安裝資料庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟體源 sudo…

    編程 2025-04-29
  • 如何在樹莓派上安裝Windows 7系統?

    隨著樹莓派的普及,許多用戶想在樹莓派上安裝Windows 7操作系統。 一、準備工作 在開始之前,需要準備以下材料: 1.樹莓派4B一台; 2.一張8GB以上的SD卡; 3.下載並…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • 資料庫第三範式會有刪除插入異常

    如果沒有正確設計資料庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係資料庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • 分銷系統開發搭建

    本文主要介紹如何搭建一套完整的分銷系統,從需求分析、技術選型、開發、部署等方面進行說明。 一、需求分析 在進行分銷系統的開發之前,我們首先需要對系統進行需求分析。一般來說,分銷系統…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的資料庫存儲引擎

    本文將介紹兩款高性能的資料庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28
  • Python怎麼導入資料庫

    Python是一種高級編程語言。它具有簡單、易讀的語法和廣泛的庫,讓它成為一個靈活和強大的工具。Python的資料庫連接類型可以多種多樣,其中包括MySQL、Oracle、Post…

    編程 2025-04-28
  • Java批量執行SQL時Communications Link Failure Socket is Closed問題解決辦法

    對於Java開發人員來說,批量執行SQL是一個經常會遇到的問題。但是,有時候我們會遇到「Communications link failure socket is closed」這…

    編程 2025-04-28

發表回復

登錄後才能評論