小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Informix 數(shù)據(jù)備份技巧...

 昵稱90415 2009-02-24
Informix 數(shù)據(jù)備份技巧
 
作者:  出處:Unix愛好者家園unix-cd.com  更新時間: 2005年05月26日 
在大型的項目開發(fā)中,一個項目組通常會在小型的模擬環(huán)境中進行初步開發(fā),待系統(tǒng)初步穩(wěn)定后,再把開發(fā)環(huán)境移到新系統(tǒng)中,最后才把舊系統(tǒng)切換到新系統(tǒng)中去。但在模擬環(huán)境中,一般數(shù)據(jù)庫服務器的配置都較低,而且不會有專門的數(shù)據(jù)備份措施,一旦掉電或誤操作,便容易出現(xiàn)數(shù)據(jù)丟失、數(shù)據(jù)庫毀壞的情況,開發(fā)人員的一番心血便會白費。因此,需要一種簡單而又有效的數(shù)據(jù)備份方法。  
  
我們假設模擬環(huán)境的數(shù)據(jù)庫服務器的操作系統(tǒng)是Rerhat Linux 7,數(shù)據(jù)庫服務器為Informix Online Dynamic Server 7.0,需要備份的數(shù)據(jù)庫名稱為dbtemp。在開發(fā)過程中,我們要求能對數(shù)據(jù)庫表結(jié)構(gòu)和其中的數(shù)據(jù)每天都能定時進行自動備份。因此我們需要使用crontab進行工作日程安排,crontab是操作每個用戶的守護程序和該執(zhí)行的時間表。  
crontab文件的格式:M H D m d cmd。  
M: 分鐘(0-59)。  
H:小時(0-23)。   
D:天(1-31)。   
m: 月(1-12)。   
d: 一星期內(nèi)的天(0~6,0為星期天)。   
cmd要運行的程序,程序被送入sh執(zhí)行,這個shell只有USER,HOME,SHELL這三個環(huán)境變量。  
  
root用戶使用crontab -e命令編輯crontab文件,在本例中,文件內(nèi)容如下:  
#backup zhdata start;  
24 15 * * * su -l -c "dbschema -d dbtemp -ss /opt/informix/data/dbtemp.sql" informix  
25 15 * * * su -l -c "dbaccess dbtemp /opt/informix/data/create_unload.sql" informix  
27 15 * * * su -l -c "dbaccess dbtemp /opt/informix/data/unload.sql" informix  
#backup zhdata end;  
文件中的第一條語句指定每天下午3點24分創(chuàng)建數(shù)據(jù)庫dbtemp模式文件dbtemp.sql;第二條語句指定每天下午3點25分使用dbaccess執(zhí)行create_unload.sql 文件,create_unload.sql文件內(nèi)容如下:  
  
UNLOAD TO /opt/Informix/data/unload.sql DELIMITER ';'  
SELECT "unload to /opt/informix/data/"||tabname||  
".txt delimiter '$' select * from "||tabname  
FROM systables WHERE tabid > 99  
  
這是一條嵌套式SQL語句,能夠把數(shù)據(jù)庫中的除系統(tǒng)表以外的所有表找出來。假設數(shù)據(jù)庫中除了系統(tǒng)表外,還有用戶表userinfo1,userinfo2,.…,userinfon,那么執(zhí)行該語句后生成的unload.sql文件內(nèi)容將為:  
  
unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfo1;  
unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfo2;  
……  
unload to /opt/Informix/data/userinfo1.txt delimiter '$' select * from userinfon;  
  
然后第3條語句指定每天下午3點27分使用dbaccess執(zhí)行unload.sql文件,unload語句完成的是把表中的數(shù)據(jù)內(nèi)容倒出成以指定分隔符分隔字段的文本文件;在本例中,unload.sql文件實現(xiàn)導出數(shù)據(jù)庫中出系統(tǒng)表以外的各表數(shù)據(jù),生成以'$'符號分隔的文本文件,即把數(shù)據(jù)庫除系統(tǒng)表以外的各表數(shù)據(jù)都導成以'$'符號分隔的文本文件,存放在/opt/Informix/data目錄下面。這樣,一個簡單的數(shù)據(jù)備份便完成了。

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多