⑴ sql server如何單獨備份
使用場景:sql server資料庫備份單個表的結構和數據,在我們要修改正式系統的數據的一天或者多條某些數據時候,要執行update語句操作,安全穩健考慮,最好先做好所修改的表的結構和數據備份!
⑵ sql server 2005資料庫備份一個表的sql語句怎麼樣寫
不存在這樣的備份手段 sql server
你可以使用job 定時將你的表數據導入到另外一個資料庫a的表 那個資料庫a只存在這個表 然後你備份這個資料庫a就可以了
⑶ SQL怎樣用SQL語句備份一張數據表
「AS 附近有語法錯誤」這個提示應該是SQL SERVER的,可見樓主是在SQL Server里執行的,而create table ... as是ORACLE的語句,在SQL Server里是不能執行的,SQL Server里類似的就是select * into person_backup from person。
⑷ sql server 如何用sql語句實現單個表的備份和還原。
是什麼版本的資料庫?下面是找到的2008的操作步驟:
SQL
SERVER
2008
怎麼導入和導出單張表的數據和結構
(1)右擊需要導出數據的資料庫,在彈出式菜單中選擇「任務」下的「生成腳本」選項。
(2)在腳本向導的選擇腳本選項中,將「編寫數據的腳步」選擇為TRUE,這里默認是為FALSE的。
(3)然後下一步選擇導出的對象,選擇導出的表,最後完成時,即可以看到由系統導出的表定義和表數據了。
⑸ oracle 資料庫備份語句
EXP 畢竟也需要連接到資料庫,也就是需要提供用戶名,密碼,所以你說的資料庫模式導出,是無法正常實現的。但是使用DBA用戶登陸,可以實現導出整個資料庫的類似功能。
資料庫模式:
EXP SYSTEM/PASSWD@ORACLE FULL = Y FILE = 'DB081222.DMP' LOG = 'DB081222.LOG'
用戶模式:
EXP USER/PASSWD@ORACLE FILE = 'USER081222.DMP' LOG = 'USER081222.LOG'
表模式:
EXP USER/PASSWD@ORACLE FILE = 'USER081222.DMP' LOG = 'USER081222.LOG' TABLES = ('TABLE_1','TABLE_2')
IMP 語句只要把上面3個語句中的 'EXP' 換成 'IMP' 就行了
如果還有不明白的,可以在命令行中輸入EXP -HELP 或者 IMP -HELP 查看幫助!
⑹ sqlserver資料庫如何備份單張表
1、首先找好要備份的數據表,如下圖所示。
⑺ 如何只備份一張資料庫表
mysqlmp -uroot --password=密碼 --opt資料庫名 表名 > 備份的名稱
例子:mysqlmp -uroot --password=psw --optVOD recfile >recfile.sql
備份資料庫VOD下的recfile表,如果只想保留表的結構而不帶數據
mysqlmp -uroot --password=psw --optVOD recfile -d >recfile.sql
(7)資料庫備份單表語句擴展閱讀:
Sqlserver備份語句
1、完整備份
Backup Database NorthwindCS
To disk='G:BackupNorthwindCS_Full_20070908.bak'
2、差異備份
Backup Database NorthwindCS
To disk='G:BackupNorthwindCS_Diff_20070908.bak'
With Differential
3、日誌備份 ,默認截斷日誌
Backup Log NorthwindCS
To disk='G:BackupNorthwindCS_Log_20070908.bak'
4、日誌備份, 不截斷日誌
Backup Log NorthwindCS
To disk='G:BackupNorthwindCS_Log_20070908.bak'
With No_Truncate
5、文件備份
Exec Sp_Helpdb NorthwindCS --查看數據文件
Backup Database NorthwindCS
File='NorthwindCS' --數據文件的邏輯名
To disk='G:BackupNorthwindCS_File_20070908.bak'
⑻ 關於資料庫備份語句誰給我講解下
oracle雙機熱備份方法
一、創建Standby Database 要求
1、 Primary 與standby 資料庫所在主機上的oracle server及*作系統版本必須相同,且具有相同的補丁;
2、 primary 資料庫必須為archive mode;Standby Database也必須為archive mode ;
二、創建standby資料庫
1、 首先查看Primary Database的歸檔模式(svrmgr>archive log list)若為無歸檔模式,將資料庫轉換為自動歸檔方式,方法如下:
先關閉Primary Database:
svrmgr>shutdown immediate
再以mount方式啟動Primary Database:
svrmgr>connect internal/password
svrmgr>startup mount
svrmgr>alter database archivelog
svrmgr>shutdown
2、修改init%oracle_sid%.ora 文件中的參數,加入:
log_archive_start = true # if you want automatic archiving
log_archive_dest=%ORACLE_HOME%\database\archive
log_archive_format = %ORACLE_SID%%S.%T其中log_archive_dest
是指歸檔日誌文件存放的位置,可根據實際情況來設定,如E 盤空間較
大,可以設為:log_archive_dest=e:\oracle\database\archive
3、復制Primary Database 的init%oracle_sid%.ora 和對應的Password 文件 到 Standby Database 上的目錄%oracle_home%\database;根據實際情況修改Standby Database上的對應init%oracle_sid%.ora中的參數:
log_archive_dest;
4、在Standby Database位於的主機上創建實例,實例名稱同Primary Database,例如:
Oradim80 –new –sid SID_NAME –intpwd oracle –startmode auto – pfile=c:\orant\database\init%oracle_sid%.ora;
5、在Primary Database上為Standby創建Controlfile,將controlfile 拷貝至 Standby Database 的確定位置,*作如下:
svrmgr>alter database create standby controlfile as ;
6、在Primary Database上將聯機日誌歸檔,
svrmgr>alter system archive log current;
7、關閉Primary Database,
svrmgr>shutdown immediate
8、從Primary Database上將所有數據文件、日誌文件、歸檔日誌文件(不包括控制文件)拷貝至Standby Database的確定位置;
9、以nomount方式啟動Standby Database:
svrmgr>startup nomount
svrmgr>alter database mount standby database[execlusive/parallel]
10、同步Standby Database:
svrmgr>recover standby database;
11、恢復Primary Database 啟動狀態。
三、維護standby資料庫
1、 將primary資料庫所產生的archive log文件定期傳到standby資料庫的確定位置;手工的做恢復,使standby資料庫與primary資料庫保持同步。
svrmgr> set autorecovery on;
svrmgr> connect internal/password;
svrmgr> startup nomount pfile=;
svrmgr> alter database mount standby database;
svrmgr> recover standby database;
svrmgr> shutdown
2、當primary 資料庫失敗時,將standby 資料庫激活:取消(cancel)恢復執行以下*作:
svrmgr> connect internal/password;
svrmgr> startup nomount pfile=;
svrmgr> alter database mount standby database;
svrmgr>alter database activate standby database;
shutdown standby 資料庫;
svrmgr>shutdown immediate
重起Standby Database;
svrmgr>startup
⑼ 備份MYSQL資料庫SQL語句怎麼寫
mysqlmp備份還原和mysqlmp導入導出語句大全詳解
mysqlmp備份:
mysqlmp -u用戶名 -p密碼 -h主機資料庫 a -w "sql條件" --lock-all-tables >路徑
案例:
mysqlmp -uroot -p1234 -hlocalhost db1 a -w "id in (select id from b)" --lock-all-tables > c:\aa.txt
mysqlmp還原:
mysqlmp -u用戶名 -p密碼 -h主機資料庫<路徑
案例:
mysql -uroot -p1234 db1 < c:\aa.txt
mysqlmp按條件導出:
mysqlmp -u用戶名 -p密碼 -h主機資料庫 a --where "條件語句" --no-建表>路徑
mysqlmp -uroot -p1234 dbname a --where "tag='88'" --no-create-info> c:\a.sql
mysqlmp按導入:
mysqlmp -u用戶名 -p密碼 -h主機資料庫<路徑
案例:
mysql -uroot -p1234 db1 < c:\a.txt
mysqlmp導出表:
mysqlmp -u用戶名 -p密碼 -h主機資料庫表
案例:
mysqlmp -uroot -p sqlhk9 a --no-data
講一下 mysqlmp 的一些主要參數
--compatible=name
它告訴 mysqlmp,導出的數據將和哪種資料庫或哪個舊版本的 MySQL 伺服器相兼容。值可以為 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用幾個值,用逗號將它們隔開。當然了,它並不保證能完全兼容,而是盡量兼容。
--complete-insert,-c
導出的數據採用包含欄位名的完整 INSERT 方式,也就是把所有的值都寫在一行。這么做能提高插入效率,但是可能會受到 max_allowed_packet 參數的影響而導致插入失敗。因此,需要謹慎使用該參數,至少我不推薦。
--default-character-set=charset
指定導出數據時採用何種字元集,如果數據表不是採用默認的 latin1 字元集的話,那麼導出時必須指定該選項,否則再次導入數據後將產生亂碼問題。
--disable-keys
告訴 mysqlmp 在 INSERT 語句的開頭和結尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 語句,這能大大提高插入語句的速度,因為它是在插入完所有數據後才重建索引的。該選項只適合 MyISAM 表。
--extended-insert = true|false
默認情況下,mysqlmp 開啟 --complete-insert 模式,因此不想用它的的話,就使用本選項,設定它的值為 false 即可。
--hex-blob
使用十六進制格式導出二進制字元串欄位。如果有二進制數據就必須使用本選項。影響到的欄位類型有 BINARY、VARBINARY、BLOB。
--lock-all-tables,-x
在開始導出之前,提交請求鎖定所有資料庫中的所有表,以保證數據的一致性。這是一個全局讀鎖,並且自動關閉 --single-transaction 和 --lock-tables 選項。
--lock-tables
它和 --lock-all-tables 類似,不過是鎖定當前導出的數據表,而不是一下子鎖定全部庫下的表。本選項只適用於 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 選項。
--no-create-info,-t
只導出數據,而不添加 CREATE TABLE 語句。
--no-data,-d
不導出任何數據,只導出資料庫表結構。
--opt
這只是一個快捷選項,等同於同時添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 選項。本選項能讓 mysqlmp 很快的導出數據,並且導出的數據能很快導回。該選項默認開啟,但可以用 --skip-opt 禁用。注意,如果運行 mysqlmp 沒有指定 --quick 或 --opt 選項,則會將整個結果集放在內存中。如果導出大資料庫的話可能會出現問題。
--quick,-q
該選項在導出大表時很有用,它強制 mysqlmp 從伺服器查詢取得記錄直接輸出而不是取得所有記錄後將它們緩存到內存中。
--routines,-R
導出存儲過程以及自定義函數。
--single-transaction
該選項在導出數據之前提交一個 BEGIN SQL語句,BEGIN 不會阻塞任何應用程序且能保證導出時資料庫的一致性狀態。它只適用於事務表,例如 InnoDB 和 BDB。
本選項和 --lock-tables 選項是互斥的,因為 LOCK TABLES 會使任何掛起的事務隱含提交。
要想導出大表的話,應結合使用 --quick 選項。
--triggers
同時導出觸發器。該選項默認啟用,用 --skip-triggers 禁用它。
其他參數詳情請參考手冊,我通常使用以下 SQL 來備份 MyISAM 表:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob -x db_name > db_name.sql
使用以下 SQL 來備份 Innodb 表:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob --single-transaction db_name > db_name.sql
另外,如果想要實現在線備份,還可以使用 --master-data 參數來實現,如下:
/usr/local/mysql/bin/mysqlmp -uyejr -pyejr "
--default-character-set=utf8 --opt --master-data=1 "
--single-transaction --flush-logs db_name > db_name.sql
它只是在一開始的瞬間請求鎖表,然後就刷新binlog了,而後在導出的文件中加入CHANGE MASTER 語句來指定當前備份的binlog位置,如果要把這個文件恢復到slave里去,就可以採用這種方法來做。
1.2 還原
用 mysqlmp 備份出來的文件是一個可以直接倒入的 SQL 腳本,有兩種方法可以將數據導入。
直接用 mysql 客戶端
例如:
/usr/local/mysql/bin/mysql -uyejr -pyejr db_name < db_name.sql
用 SOURCE 語法(實驗不成功!!!)
其實這不是標準的 SQL 語法,而是 mysql 客戶端提供的功能,例如:
SOURCE /tmp/db_name.sql;
這里需要指定文件的絕對路徑,並且必須是 mysqld 運行用戶(例如 nobody)有許可權讀取的文件。
⑽ 請教用sql語句給資料庫表備份
如果你的資料庫是ORACLE:
c:\>exp system/password owner(user1,user2,...) file='dbbackup20090718-1.dmp' log='dbbackup20090718-1.log' buffer=65530
執行後會在c盤根目錄下備份文件,如果要讓備份文件存放在其他位置,可以給file和log加上路徑。