當前位置:首頁 » 網頁前端 » 資料庫備份腳本
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

資料庫備份腳本

發布時間: 2022-02-04 01:56:49

① oracle資料庫如何每天自動執行腳本完成正式資料庫到備份資料庫的備份

寫個腳本完成正式資料庫到備份資料庫的備份
再設定Task Schele 每天某個時間自動執行這個腳本

sql server備份腳本

use master
go
if object_id('sp_restoreDB') is not null
drop proc sp_restoreDB
go
create proc sp_restoreDB(
@DBName sysname,--資料庫名
@RestoreFiles nvarchar(1000)--路徑如:c:\
)
as
declare @S nvarchar(4000),@BackName nvarchar(200)
set @BackName='backup'+convert(varchar(8),getdate(),112)+'.bak'
set @S='BACKUP DATABASE ['+@DBName+'] TO DISK = N'''+@RestoreFiles+@BackName+''' WITH NOFORMAT, NOINIT, SKIP, NOREWIND, NOUNLOAD, STATS = 10'
exec(@S)

③ 怎樣寫資料庫備份腳本

你知道怎麼在bash裡面備份資料庫就可以自動了寫成腳本
添加到計劃任務就OK了

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

蛙蛙推薦:利用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的強大。

⑤ 怎麼備份遠程mysql資料庫的腳本文件

在MySQL中進行數據備份的方法有兩種:
1. mysqlhot
這個命令會在拷貝文件之前會把表鎖住,並把數據同步到數據文件中,以避免拷貝到不完整的數據文件,是最安全快捷的備份方法。
命令的使用方法是:
mysqlhot -u root -p<rootpass> db1 db2 … dbn <output_dir>
如果需要備份全部資料庫,可以加上–regexp=」.*」參數。
Mysqlhot命令可自動完成數據鎖定工作,備份時不用關閉伺服器。它還可以刷新日誌,使備份文件和日誌文件的檢查點能保持同步。
2. mysqlmp
這個命令是用來把資料庫倒成sql文件的,是非常古老的命令了。
命令的使用方法是:
mysqlmp -u root -p<rootpass> –hex-blob db1 > db1.sql
加上–hex-blob參數以後,blob數據會被類似BASE64的方法轉換為文本來存儲在sql文件中,就不會導致sql文件格式問題了。經過測試,通過這種方法備份的blob數據再重新恢復回去能夠完全正確。
如果要備份所有的資料庫,可以加上–all-databases參數。
用mysqlmp命令還可直接把資料庫轉移到另外一台伺服器上,不用生成備份文件。重復執行可定期更新遠程資料庫。
% mysqladmin -h remote_host create testdb
% mysqlmp –opt testdb | mysql -h remote_host testdb
另外還可通過ssh遠程調用伺服器上的程序,如:
% ssh remote_host mysqladmin create testdb

⑥ Oracle資料庫備份腳本怎麼寫

沒必要用root許可權執行,oracle用戶同樣可以執行crontab計劃任務
1、su - oracle
crontab -e
0 4 * * 0 /home/oracle/exp.sh 2>&1 >>/home/oracle/script_exp.log;
0~59 表示分
0~23 表示小時
1~31 表示日
1~12 表示月份
0~6 表示星期(其中0表示星期日)
2、cat /home/oracle/exp.sh
. ~/.bash_profile
bakdir=/opt/dbbak
logdir=/home/oracle/dbbak
rq=$(date +%Y%m%d)
exp system/***** owner=jysh file=${bakdir}/jysh_${rq}.dmp log=${logdir}/jysh_${rq}.log;
find ${bakdir} -type f -mtime +30 -exec rm -rf {} \;

⑦ Oracle 10g資料庫寫腳本如何備份和恢復數據

在windows開始-->運行中輸入cmd回車進入1、執行以下命令將資料庫導出(例如用戶名為test,密碼為test,資料庫實例為orcl,將其備份在F盤中命名為backup.dmp)exp test/test@orcl file = F:\backup.dmp2、執行以下命令將資料庫導入新的實例中(用戶名為test1,密碼為test1,實例名為test1)imp test1/test1@test1 file=F:\backup.dmp fromuser=test touser=test1

⑧ oracle資料庫如何導出整個資料庫腳本,用於備份資料庫

首先按full方式做exp導出(為了加快速度可以設置rows=no),然後做imp導入這里注意設置個indexfile=xxx.txt 參數這樣就能將你創建所有對象的腳本輸出到xxx.txt文件里了。當然了你可以使用工具如:toad,會有導出script的選項更方便點。

⑨ 資料庫給出個腳本文件和資料庫備份怎麼連接啊

引用樓主
houyong8151
的回復:資料庫給出個腳本文件和資料庫備份怎麼連接啊!各位大哥大姐給幫幫忙,弄了好長時間都沒弄出來!謝謝了~~可以請教請教!腳本文件是創建某些東西用的.資料庫備份是用來恢復資料庫用的,兩者幾乎沒有關系.

⑩ 請教大師們,想要從備份一份資料庫腳本,回家用 任務-編寫腳本,不是創建庫的語句,怎麼搞

BACKUP DATABASE [資料庫名] TO DISK = N'D:\備份名.bak' WITH NOFORMAT, NOINIT, NAME = N'資料庫名-完整 資料庫 備份', SKIP, NOREWIND, NOUNLOAD, STATS = 10
GO