數(shù)據(jù)庫設(shè)計(jì)規(guī)范(初稿)v1.0_第1頁
數(shù)據(jù)庫設(shè)計(jì)規(guī)范(初稿)v1.0_第2頁
數(shù)據(jù)庫設(shè)計(jì)規(guī)范(初稿)v1.0_第3頁
數(shù)據(jù)庫設(shè)計(jì)規(guī)范(初稿)v1.0_第4頁
數(shù)據(jù)庫設(shè)計(jì)規(guī)范(初稿)v1.0_第5頁
已閱讀5頁,還剩35頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

數(shù)據(jù)庫設(shè)計(jì)文檔 李偉 2010-12-25

目錄1. 數(shù)據(jù)庫物理設(shè)計(jì)原那么 51.1. 數(shù)據(jù)庫環(huán)境配置原那么 51.1.1. 操作系統(tǒng)環(huán)境 51.1.2. 內(nèi)存要求 51.1.3. 交換區(qū)設(shè)計(jì) 51.1.4. 其他 61.2. 數(shù)據(jù)庫設(shè)計(jì)原那么 61.2.1. 數(shù)據(jù)庫SID 61.2.2. 數(shù)據(jù)庫全局名 61.2.3. 數(shù)據(jù)庫類型選擇 61.2.4. 數(shù)據(jù)庫連接類型選擇 71.2.5. 數(shù)據(jù)庫SGA配置 71.2.6. 數(shù)據(jù)庫字符集選擇 81.2.7. 數(shù)據(jù)庫其他參數(shù)配置 91.2.8. 數(shù)據(jù)庫控制文件配置 91.2.9. 數(shù)據(jù)庫日志文件配置 101.2.10. 數(shù)據(jù)庫回滾段配置 101.2.11. 數(shù)據(jù)庫臨時(shí)段表空間配置 11. 數(shù)據(jù)庫系統(tǒng)表空間配置 111.3. 數(shù)據(jù)庫表空間設(shè)計(jì)原那么 111.3.1. 表空間大小定義原那么 111.3.2. 表空間擴(kuò)展性設(shè)計(jì)原那么 121.4. 裸設(shè)備的使用 122. 數(shù)據(jù)庫邏輯設(shè)計(jì)原那么 132.1. 命名標(biāo)準(zhǔn) 132.1.1. 表屬性標(biāo)準(zhǔn) 132.1.2. 索引 142.1.3. 視圖 152.1.4. 實(shí)體化視圖 152.1.5. 存儲(chǔ)過程 152.1.6. 觸發(fā)器 152.1.7. 函數(shù) 162.1.8. 數(shù)據(jù)包 162.1.9. 序列 162.1.10. 表空間 162.1.11. 數(shù)據(jù)文件 162.1.12. 普通變量 162.1.13. 游標(biāo)變量 17. 記錄型變量 172.1.15. 表類型變量 172.1.16. 數(shù)據(jù)庫鏈 172.2. 命名 172.2.1. 語言 172.2.2. 大小寫 182.2.3. 單詞分隔 182.2.4. 保存字 182.2.5. 命名長度 182.2.6. 字段名稱 182.3. 數(shù)據(jù)類型 182.3.1. 字符型 182.3.2. 數(shù)字型 192.3.3. 日期和時(shí)間 192.3.4. 大字段 192.3.5. 唯一鍵 192.4. 設(shè)計(jì) 202.4.1. 范式 202.4.2. 表設(shè)計(jì) 202.4.3. 索引設(shè)計(jì) 232.4.4. 視圖設(shè)計(jì) 242.4.5. 包設(shè)計(jì) 242.4.6. 平安性設(shè)計(jì) 252.5. SQL編寫 262.5.1. 字符類型數(shù)據(jù) 262.5.2. 復(fù)雜sql 272.5.3. 高效性 272.5.4. 健壯性 282.5.5. 平安性 292.5.6. 完整性 303. 備份恢復(fù)設(shè)計(jì)原那么 303.1. 數(shù)據(jù)庫exp/imp備份恢復(fù) 303.1.1. 數(shù)據(jù)庫級(jí)備份原那么 303.1.2. 用戶級(jí)備份原那么 303.1.3. 表級(jí)備份原那么 313.2. 數(shù)據(jù)庫冷備份原那么 313.3. Rman備份恢復(fù)原那么 313.3.1. Catalog數(shù)據(jù)庫 313.3.2. ArchiveLog 333.3.3. 全備份策略 333.3.4. 增量備份策略 333.3.5. 恢復(fù)原那么 333.4. 備用數(shù)據(jù)庫原那么 343.5. 一些小經(jīng)驗(yàn) 343.6. 系統(tǒng)調(diào)優(yōu)知識(shí) 353.6.1. 生成狀態(tài)報(bào)表〔statspack的使用〕 353.6.2. sql追蹤 363.6.3. 內(nèi)存調(diào)整 373.6.4. 排序的優(yōu)化 403.6.5. 統(tǒng)計(jì)信息 414. 設(shè)計(jì)工具 42

數(shù)據(jù)庫物理設(shè)計(jì)原那么數(shù)據(jù)庫環(huán)境配置原那么操作系統(tǒng)環(huán)境對于中小型數(shù)據(jù)庫系統(tǒng),采用linux操作系統(tǒng)比擬適宜,對于數(shù)據(jù)庫冗余要求負(fù)載均衡能力要求較高的系統(tǒng),可以采用Oracle10gRAC的集群數(shù)據(jù)庫的方法,集群節(jié)點(diǎn)數(shù)范圍在2—64個(gè)。對于大型數(shù)據(jù)庫系統(tǒng),可以采用SunSolarisSPARC64位小型機(jī)系統(tǒng)或HP9000系列小型機(jī)系統(tǒng)。RAD5適合只讀操作的數(shù)據(jù)庫,RAD1適合OLTP數(shù)據(jù)庫。內(nèi)存要求對于linux操作系統(tǒng)下的數(shù)據(jù)庫,由于在正常情況下Oracle對SGA的管理能力不超過1.7G。所以總的物理內(nèi)存在4G以下。SGA的大小為物理內(nèi)存的50%—75%。對于64位的小型系統(tǒng),Oracle數(shù)據(jù)庫對SGA的管理超過2G的限制,SGA設(shè)計(jì)在一個(gè)適宜的范圍內(nèi):物理內(nèi)存的50%—70%,當(dāng)SGA過大的時(shí)候會(huì)導(dǎo)致內(nèi)存分頁,影響系統(tǒng)性能。交換區(qū)設(shè)計(jì)當(dāng)物理內(nèi)存在2G以下的情況下,交換分區(qū)swap為物理內(nèi)存的3倍,當(dāng)物理內(nèi)存>2G的情況下,swap大小為物理內(nèi)存的1—2倍。其他其他環(huán)境變量參考Oracle相關(guān)的安裝文檔和隨機(jī)文檔。數(shù)據(jù)庫設(shè)計(jì)原那么數(shù)據(jù)庫SID數(shù)據(jù)庫SID是唯一標(biāo)志數(shù)據(jù)庫的符號(hào),命名長度不能超過5個(gè)字符。對于單節(jié)點(diǎn)數(shù)據(jù)庫,以字符開頭的5個(gè)長度以內(nèi)字串作為SID的命名。對于集群數(shù)據(jù)庫,當(dāng)命名SID后,各節(jié)點(diǎn)SID自動(dòng)命名為SIDnn,其中nn為節(jié)點(diǎn)號(hào):1,2,…,64。例如rac1、rac2、rac24。數(shù)據(jù)庫全局名數(shù)據(jù)庫全局名稱:<sid>.domain數(shù)據(jù)庫類型選擇對于海量數(shù)據(jù)庫系統(tǒng),采用datawarehouse的類型。對于小型數(shù)據(jù)庫或OLTP類型的數(shù)據(jù)庫,采用TransactionProcessing類型。數(shù)據(jù)庫連接類型選擇Oracle數(shù)據(jù)庫有專用效勞器連接類型和多線程效勞器MTS連接類型。對于批處理效勞,需要專用效勞器連接方式,而對于OLTP效勞那么MTS的連接方式比擬適宜。由于采用MTS后,可以通過配置網(wǎng)絡(luò)效勞實(shí)現(xiàn)某些特定批處理效勞采用專用效勞器連接方式,所以數(shù)據(jù)庫設(shè)計(jì)時(shí)一般采用MTS類型。數(shù)據(jù)庫SGA配置數(shù)據(jù)庫SGA可以采用手工配置或按物理內(nèi)存比例配置,在數(shù)據(jù)庫初始設(shè)計(jì)階段采用按比例配置方式,在實(shí)際應(yīng)用中按系統(tǒng)調(diào)優(yōu)方式修改SGA。數(shù)據(jù)庫字符集選擇為了使數(shù)據(jù)庫能夠正確支持多國語言,必須配置適宜的數(shù)據(jù)庫字符集,采用UTF8字符集。注意:如果沒有大對象,在使用過程中進(jìn)行語言轉(zhuǎn)換沒有什么影響,具體過程如下〔切記設(shè)定的字符集必須是ORACLE支持,不然不能start〕SQL>shutdownimmediate;SQL>startupmount;SQL>altersystemenablerestrictedsession;SQL>altersystemsetjob_queue_processes=0;SQL>alterdatabaseopen;SQL>alterdatabasecharactersetinternal_usewe8iso8859p1;SQL>shutdownimmediate;SQL>startup數(shù)據(jù)庫其他參數(shù)配置DB_FILESDb_files是數(shù)據(jù)庫能夠同時(shí)翻開的文件數(shù)量,默認(rèn)值是200個(gè)。當(dāng)數(shù)據(jù)庫規(guī)劃時(shí)文件數(shù)量FILES接近或超過200個(gè)時(shí)候,按以下估計(jì)值配置:DB_FILES=FILES*1.5Db_block_size一個(gè)extent要是5個(gè)blocks的倍數(shù)為好,如:一個(gè)blocks是4096字節(jié),那一個(gè)extent就是2M、4M或8M為好。Db_block_size是數(shù)據(jù)庫最小物理單元,一旦數(shù)據(jù)庫創(chuàng)立完成,該參數(shù)無法修改,db_block_size按以下規(guī)那么調(diào)整:數(shù)據(jù)倉庫類型:db_block_size盡可能大,采用8192或16384OLTP類型:db_block_size用比擬小的取值范圍:2048或4096Blocks推薦是系統(tǒng)操作的塊倍數(shù)〔裸設(shè)備塊大小是512字節(jié),NTFS是4K,使用8K的方式在大局部系統(tǒng)上通用〕。數(shù)據(jù)庫控制文件配置控制文件鏡象多個(gè)控制文件存放在不同的物理位置。控制文件配置控制文件中參數(shù)設(shè)置,最大的數(shù)據(jù)文件數(shù)量不能小于數(shù)據(jù)庫參數(shù)db_files。數(shù)據(jù)庫日志文件配置日志文件大小日志文件的大小由數(shù)據(jù)庫事務(wù)處理量決定,在設(shè)計(jì)過程中,確保每20分鐘切換一個(gè)日志文件。所以對于批處理系統(tǒng),日志文件大小為幾百M(fèi)到幾G的大小。對于OLTP系統(tǒng),日志文件大小為幾百M(fèi)以內(nèi)。日志文件組數(shù)量對于批處理系統(tǒng),日志文件組為5—10組;對于OLTP系統(tǒng),日志文件組為3—5組,每組日志大小保持一致;對于集群數(shù)據(jù)庫系統(tǒng),每節(jié)點(diǎn)有各自獨(dú)立的日志組。日志成員數(shù)量為了確保日志能夠鏡象作用,每日志組的成員為2個(gè)。數(shù)據(jù)庫回滾段配置在Oracle9i數(shù)據(jù)庫中,設(shè)計(jì)Undo表空間取代以前版本的回滾段表空間。Undo表空間大小的設(shè)計(jì)標(biāo)準(zhǔn)由以下公式計(jì)算:Undospace=UR*UPS*db_block_size+冗余量UR:表示在undo中保持的最長時(shí)間數(shù)〔秒〕,由數(shù)據(jù)庫參數(shù)UNDO_RETENTION值決定。UPS:表示在undo中,每秒產(chǎn)生的數(shù)據(jù)庫塊數(shù)量。例如:在數(shù)據(jù)庫中保存2小時(shí)的回退數(shù)據(jù),假定每小時(shí)產(chǎn)生200個(gè)數(shù)據(jù)庫塊。那么Undospace=2*3600*200*4K=5.8G。數(shù)據(jù)庫臨時(shí)段表空間配置數(shù)據(jù)庫臨時(shí)段表空間根據(jù)實(shí)際生產(chǎn)環(huán)境情況調(diào)整其大小,表空間屬性為自動(dòng)擴(kuò)展。數(shù)據(jù)庫系統(tǒng)表空間配置系統(tǒng)表空間大小1G左右,除了存放數(shù)據(jù)庫數(shù)據(jù)字典的數(shù)據(jù)外,其他數(shù)據(jù)不得存儲(chǔ)在系統(tǒng)表空間。數(shù)據(jù)庫表空間設(shè)計(jì)原那么表空間大小定義原那么當(dāng)表空間大小小于操作系統(tǒng)對最大文件限制時(shí),表空間由一個(gè)文件組成。如果表空間大小大于操作系統(tǒng)對最大文件限制時(shí),該表空間由多個(gè)數(shù)據(jù)文件組成,表空間的總大小為估算為:Tablespace+sum(數(shù)據(jù)段+索引段)*150%。表空間擴(kuò)展性設(shè)計(jì)原那么表空間數(shù)據(jù)文件采用自動(dòng)擴(kuò)展的方式,擴(kuò)展容量快大小按2的整數(shù)倍〔1M、2M、4M、8M、16M、32M、64M〕進(jìn)行擴(kuò)展,創(chuàng)立表空間時(shí)盡量采用nologing選項(xiàng)。表空間的最大限制一般采用unlimited,除非確切知道表空間數(shù)據(jù)文件的最大使用范圍?!惨话鉾indows32位系統(tǒng)的文件最大2G,64位的unix系統(tǒng)系統(tǒng)文件最大128G,但也要注意文件格式設(shè)定的文件大小〕,建議最大為2G。表空間采用local管理方式,例如:CREATETABLESPACETBS_USERINFODATAFILE‘/oradata/tbs_userinfo.dbf’SIZE8M REUSEAUTOEXTENDONNEXT2MMAXSIZEUNLIMITEDNOLOGGINGEXTENTMANAGEMENTLOCALAUTOALLOCATESEGMENTSPACEMANAGEMENTAUTO;裸設(shè)備的使用一個(gè)scsi設(shè)備可以14個(gè)分區(qū),unix操作系統(tǒng)256個(gè)分區(qū),性能比文件系統(tǒng)方式高15%左右,空間大于要小于(實(shí)際分區(qū)大小減兩個(gè)ORACLE的數(shù)據(jù)塊),比方100M,大于為100000K,推薦在unix使用軟連接(ln)方式把裸設(shè)備形成文件,用參加表空間時(shí)加resue選項(xiàng),當(dāng)然也可只接把設(shè)備參加表空間,移動(dòng)裸設(shè)備使用dd命令。對于windows平臺(tái),oracle提供軟連接工具,實(shí)現(xiàn)裸設(shè)備的使用,計(jì)算一條記錄的長度。數(shù)據(jù)庫邏輯設(shè)計(jì)原那么命名標(biāo)準(zhǔn)表屬性標(biāo)準(zhǔn)表名前綴為Tbl_。數(shù)據(jù)表名稱必須以有特征含義的單詞或縮寫組成,中間可以用“_”分割,例如:tbl_pstn_detail。表名稱不能用雙引號(hào)包含。表分區(qū)名前綴為p。分區(qū)名必須有特定含義的單詞或字串。例如:tbl_pstn_detail的分區(qū)p2004100101表示該分區(qū)存儲(chǔ)2004100101時(shí)段的數(shù)據(jù)。字段名字段名稱必須用字母開頭,采用有特征含義的單詞或縮寫,不能用雙引號(hào)包含。主鍵名前綴為PK_。主鍵名稱應(yīng)是前綴+表名+構(gòu)成的字段名。如果復(fù)合主鍵的構(gòu)成字段較多,那么只包含第一個(gè)字段。表名可以去掉前綴。外鍵名前綴為FK_。外鍵名稱應(yīng)是前綴+外鍵表名+主鍵表名+外鍵表構(gòu)成的字段名。表名可以去掉前綴。索引普通索引前綴為IDX_。索引名稱應(yīng)是前綴+表名+構(gòu)成的字段名。如果復(fù)合索引的構(gòu)成字段較多,那么只包含第一個(gè)字段,并添加序號(hào)。表名可以去掉前綴。主鍵索引前綴為IDX_PK_。索引名稱應(yīng)是前綴+表名+構(gòu)成的主鍵字段名,在創(chuàng)立表時(shí)候用usingindex指定主鍵索引屬性。唯一索引前綴為IDX_UK_。索引名稱應(yīng)是前綴+表名+構(gòu)成的字段名。外鍵索引前綴為IDX_FK_。索引名稱應(yīng)是前綴+表名+構(gòu)成的外鍵字段名。函數(shù)索引前綴為IDX_func_。索引名稱應(yīng)是前綴+表名+構(gòu)成的特征表達(dá)字符。蔟索引前綴為IDX_clu_。索引名稱應(yīng)是前綴+表名+構(gòu)成的簇字段。視圖前綴為V_。按業(yè)務(wù)操作命名視圖。實(shí)體化視圖前綴為MV_。按業(yè)務(wù)操作命名實(shí)體化視圖。存儲(chǔ)過程前綴為Proc_。按業(yè)務(wù)操作命名存儲(chǔ)過程。觸發(fā)器前綴為Trig_。觸發(fā)器名應(yīng)是前綴+表名+觸發(fā)器名。函數(shù)前綴為Func_。按業(yè)務(wù)操作命名函數(shù)。數(shù)據(jù)包前綴為Pkg_。按業(yè)務(wù)操作集合命名數(shù)據(jù)包。序列前綴為Seq_。按業(yè)務(wù)屬性命名。表空間公用表空間前綴為Tbs_。根據(jù)存儲(chǔ)的特性命名,例如:tbs_parameter。專用表空間Tbs_<表名稱>_nn。該表空間專門存儲(chǔ)指定的某一個(gè)表,或某一表的假設(shè)干個(gè)分區(qū)的數(shù)據(jù)。數(shù)據(jù)文件<表空間名>nn.dbf。nn=1,2,3,4,…等。普通變量前綴為Var_。存放字符、數(shù)字、日期型變量。游標(biāo)變量前綴為Cur_。存放游標(biāo)記錄集。記錄型變量前綴為Rec_。存放記錄型數(shù)據(jù)。表類型變量前綴為Tab_。存放表類型數(shù)據(jù)。數(shù)據(jù)庫鏈前綴為dbl_。表示分布式數(shù)據(jù)庫外部鏈接關(guān)系。命名語言命名應(yīng)該使用英文單詞,防止使用拼音,特別不應(yīng)該使用拼音簡寫。命名不允許使用中文或者特殊字符。英文單詞使用用對象本身意義相對或相近的單詞。選擇最簡單或最通用的單詞。不能使用毫不相干的單詞來命名。當(dāng)一個(gè)單詞不能表達(dá)對象含義時(shí),用詞組組合,如果組合太長時(shí),采用用簡或縮寫,縮寫要根本能表達(dá)原單詞的意義。當(dāng)出現(xiàn)對象名重名時(shí),是不同類型對象時(shí),加類型前綴或后綴以示區(qū)別。大小寫名稱一律大寫,以方便不同數(shù)據(jù)庫移植,以及防止程序調(diào)用問題。單詞分隔命名的各單詞之間可以使用下劃線進(jìn)行分隔。保存字命名不允許使用SQL保存字。命名長度表名、字段名、視圖名長度應(yīng)限制在20個(gè)字符內(nèi)(含前綴)。字段名稱同一個(gè)字段名在一個(gè)數(shù)據(jù)庫中只能代表一個(gè)意思。比方telephone在一個(gè)表中代表“號(hào)碼”的意思,在另外一個(gè)表中就不能代表“號(hào)碼”的意思。不同的表用于相同內(nèi)容的字段應(yīng)該采用同樣的名稱,字段類型定義。數(shù)據(jù)類型字符型固定長度的字串類型采用char,長度不固定的字串類型采用varchar。防止在長度不固定的情況下采用char類型。如果在數(shù)據(jù)遷移等出現(xiàn)以上情況,那么必須使用trim()函數(shù)截去字串后的空格。數(shù)字型數(shù)字型字段盡量采用number類型,要注意精度。日期和時(shí)間系統(tǒng)時(shí)間由數(shù)據(jù)庫產(chǎn)生的系統(tǒng)時(shí)間首選數(shù)據(jù)庫的日期型,如DATE類型。外部時(shí)間由數(shù)據(jù)導(dǎo)入或外部應(yīng)用程序產(chǎn)生的日期時(shí)間類型采用varchar類型,數(shù)據(jù)格式采用:YYYYMMDDHH24MISS。大字段如無特別需要,防止使用大字段(blob,clob,long,text,image等)。唯一鍵對于數(shù)字型唯一鍵值,盡可能用系列sequence產(chǎn)生。設(shè)計(jì)范式如無性能上的必須原因,應(yīng)該使用關(guān)系數(shù)據(jù)庫理論,到達(dá)較高的范式,防止數(shù)據(jù)冗余,但是如果在數(shù)據(jù)量上與性能上無特別要求,考慮到實(shí)現(xiàn)的方便性可以有適當(dāng)?shù)臄?shù)據(jù)冗余,但根本上要到達(dá)3NF.如非確實(shí)必要,防止一個(gè)字段中存儲(chǔ)多個(gè)標(biāo)志的做法。如11101表示5個(gè)標(biāo)志的一種取值。這往往是增加復(fù)雜度,降低性能的地方。表設(shè)計(jì)邏輯段設(shè)計(jì)原那么Tablespace每個(gè)表在創(chuàng)立時(shí)候,必須指定所在的表空間,不要采用默認(rèn)表空間以防止表建立在系統(tǒng)表空間上導(dǎo)致性能問題。對于事務(wù)比擬繁忙的數(shù)據(jù)表,必須存放在該表的專用表空間中。Pctused默認(rèn)pctused導(dǎo)致數(shù)據(jù)庫物理空間利用率非常低40%左右;對于update比擬少或update不導(dǎo)致行增大的表,pctused可設(shè)置在60—85之間;對于update能夠?qū)е滦性龃蟮谋?,update設(shè)置在40—70之間。Initrans對于需要并行查詢或者在RAC數(shù)據(jù)庫中需要并行處理的表,initrans設(shè)置為2的倍數(shù),否那么,不設(shè)該值。StorageInitial盡量減少表數(shù)據(jù)段的extents數(shù)量,initial的大小盡量接近數(shù)據(jù)段的大小64K,128K,…,1M,2M,4M,8M,16M,…,等按2的倍數(shù)進(jìn)行圓整。例如表或分區(qū)數(shù)據(jù)段大小為28M,那么initial取32M。Next表或分區(qū)擴(kuò)展extents的大小,按上述方法進(jìn)行圓整。當(dāng)表或分區(qū)數(shù)據(jù)段無法按Initial接近值進(jìn)行圓整的情況下,其大小可以按Initial+Next進(jìn)行圓整。此時(shí),必須設(shè)置Minextents=2。例如:表或分區(qū)數(shù)據(jù)段大小為150M,那么Initial=128M;Next=32M,Minextents=2。Minextents該參數(shù)表示表創(chuàng)立時(shí)候Extents的初始數(shù)量,一般取1—2。Pctincrease表示每個(gè)擴(kuò)展Extents的增長率,設(shè)置pctincrease=0能夠獲得較好的存儲(chǔ)性能。特殊表設(shè)計(jì)原那么分區(qū)表對于數(shù)據(jù)量比擬大的表,根據(jù)表數(shù)據(jù)的屬性進(jìn)行分區(qū),以得到較好的性能。如果表按某些字段進(jìn)行增長,那么采用按字段值范圍進(jìn)行范圍分區(qū);如果表按某個(gè)字段的幾個(gè)關(guān)鍵值進(jìn)行分布,那么采用列表分區(qū);對于靜態(tài)表,那么采用hash分區(qū)或列表分區(qū);在范圍分區(qū)中,如果數(shù)據(jù)按某關(guān)鍵字段均衡分布,那么采用子分區(qū)的復(fù)合分區(qū)方法。聚蔟表如果某幾個(gè)靜態(tài)表關(guān)系比擬密切,那么可以采用聚蔟表的方法。完整性設(shè)計(jì)原那么主鍵約束關(guān)聯(lián)表的父表要求有主健,主健字段或組合字段必須滿足非空屬性和唯一性要求。對于數(shù)據(jù)量比擬大的父表,要求指定索引段。外鍵關(guān)聯(lián)對于關(guān)聯(lián)兩個(gè)表的字段,一般應(yīng)該分別建立主鍵、外鍵。實(shí)際是否建立外鍵,根據(jù)對數(shù)據(jù)完整性的要求決定。為了提高性能,對于數(shù)據(jù)量比擬大的標(biāo)要求對外健建立索引。對于有要求級(jí)聯(lián)刪除屬性的外鍵,必須指定ondeletecascade。NULL值對于字段能否null,應(yīng)該在sql建表腳本中明確指明,不應(yīng)使用缺省。由于NULL值在參加任何運(yùn)算中,結(jié)果均為NULL。所以在應(yīng)用程序中必須利用nvl()函數(shù)把可能為NULL值得字段或變量轉(zhuǎn)換為非NULL的默認(rèn)值。例如:NVL〔sale,0〕。Check條件對于字段有檢查性約束,要求指定check規(guī)那么。觸發(fā)器觸發(fā)器是一種特殊的存儲(chǔ)過程,通過數(shù)據(jù)表的DML操作而觸發(fā)執(zhí)行,起作用是為確保數(shù)據(jù)的完整性和一致性不被破壞而創(chuàng)立,實(shí)現(xiàn)數(shù)據(jù)的完整約束。觸發(fā)器的before或after事務(wù)屬性的選擇時(shí)候,對表操作的事務(wù)屬性必須與應(yīng)用程序事務(wù)屬性保持一致,以防止死鎖發(fā)生。在大型導(dǎo)入表中,盡量防止使用觸發(fā)器。注釋表、字段等應(yīng)該有中文名稱注釋,以及需要說明的內(nèi)容。索引設(shè)計(jì)對于查詢中需要作為查詢條件的字段,可以考慮建立索引。最終根據(jù)性能的需要決定是否建立索引。對于復(fù)合索引,索引字段順序比擬關(guān)鍵,把查詢頻率比擬高的字段排在索引組合的最前面。在分區(qū)表中,盡量采用local分區(qū)索引以方便分區(qū)維護(hù)。除非時(shí)分區(qū)local索引,否那么在創(chuàng)立索引段時(shí)候必須指定指定索引段的tablespace、storage屬性,具體參考內(nèi)容。視圖設(shè)計(jì)視圖是虛擬的數(shù)據(jù)庫表,在使用時(shí)要遵循以下原那么:從一個(gè)或多個(gè)庫表中查詢局部數(shù)據(jù)項(xiàng);為簡化查詢,將復(fù)雜的檢索或字查詢通過視圖實(shí)現(xiàn);提高數(shù)據(jù)的平安性,只將需要查看的數(shù)據(jù)信息顯示給權(quán)限有限的人員;視圖中如果嵌套使用視圖,級(jí)數(shù)不得超過3級(jí);由于視圖中只能固定條件或沒有條件,所以對于數(shù)據(jù)量較大或隨時(shí)間的推移逐漸增多的庫表,不宜使用視圖;可以采用實(shí)體化視圖代替;除特殊需要,防止類似Select*from[TableName]而沒有檢索條件的視圖;視圖中盡量防止出現(xiàn)數(shù)據(jù)排序的SQL語句。包設(shè)計(jì)存儲(chǔ)過程、函數(shù)、外部游標(biāo)必須在指定的數(shù)據(jù)包對象PACKAGE中實(shí)現(xiàn)。存儲(chǔ)過程、函數(shù)的建立如同其它語言形式的編程過程,適合采用模塊化設(shè)計(jì)方法;當(dāng)具體算法改變時(shí),只需要修改需要存儲(chǔ)過程即可,不需要修改其它語言的源程序。當(dāng)和數(shù)據(jù)庫頻繁交換數(shù)據(jù)是通過存儲(chǔ)過程可以提高運(yùn)行速度,由于只有被授權(quán)的用戶才能執(zhí)行存儲(chǔ)過程,所以存儲(chǔ)過程有利于提高系統(tǒng)的平安性。存儲(chǔ)過程、函數(shù)必須檢索數(shù)據(jù)庫表記錄或數(shù)據(jù)庫其他對象,甚至修改〔執(zhí)行Insert、Delete、Update、Drop、Create等操作〕數(shù)據(jù)庫信息。如果某項(xiàng)功能不需要和數(shù)據(jù)庫打交道,那么不得通過數(shù)據(jù)庫存儲(chǔ)過程或函數(shù)的方式實(shí)現(xiàn)。在函數(shù)中防止采用DML或DDL語句。在數(shù)據(jù)包采用存儲(chǔ)過程、函數(shù)重載的方法,簡化數(shù)據(jù)包設(shè)計(jì),提高代碼效率。存儲(chǔ)過程、函數(shù)必須有相應(yīng)的出錯(cuò)處理功能。平安性設(shè)計(jì)管理默認(rèn)用戶在生產(chǎn)環(huán)境中,必須嚴(yán)格管理sys和system用戶,必須修改其默認(rèn)密碼,禁止用該用戶建立數(shù)據(jù)庫應(yīng)用對象。刪除或鎖定數(shù)據(jù)庫測試用戶scott。數(shù)據(jù)庫級(jí)用戶權(quán)限設(shè)計(jì)必須按照應(yīng)用需求,設(shè)計(jì)不同的用戶訪問權(quán)限。包括應(yīng)用系統(tǒng)管理用戶,普通用戶等,按照業(yè)務(wù)需求建立不同的應(yīng)用角色。用戶訪問另外的用戶對象時(shí),應(yīng)該通過創(chuàng)立同義詞對象synonym進(jìn)行訪問。角色與權(quán)限確定每個(gè)角色對數(shù)據(jù)庫表的操作權(quán)限,如創(chuàng)立、檢索、更新、刪除等。每個(gè)角色擁有剛好能夠完成任務(wù)的權(quán)限,不多也不少。在應(yīng)用時(shí)再為用戶分配角色,那么每個(gè)用戶的權(quán)限等于他所兼角色的權(quán)限之和。應(yīng)用級(jí)用戶設(shè)計(jì)應(yīng)用級(jí)的用戶帳號(hào)密碼不能與數(shù)據(jù)庫相同,防止用戶直接操作數(shù)據(jù)庫。用戶只能用帳號(hào)登陸到應(yīng)用軟件,通過應(yīng)用軟件訪問數(shù)據(jù)庫,而沒有其它途徑操作數(shù)據(jù)庫。用戶密碼管理用戶帳號(hào)的密碼必須進(jìn)行加密處理,確保在任何地方的查詢都不會(huì)出現(xiàn)密碼的明文。SQL編寫字符類型數(shù)據(jù)SQL中的字符類型數(shù)據(jù)應(yīng)該統(tǒng)一使用單引號(hào)。特別對純數(shù)字的字串,必須用單引號(hào),否那么會(huì)導(dǎo)致內(nèi)部轉(zhuǎn)換而引起性能問題或索引失效問題。利用trim(),lower()等函數(shù)格式化匹配條件。復(fù)雜sql對于非常復(fù)雜的sql(特別是有多層嵌套,帶子句或相關(guān)查詢的),應(yīng)該先考慮是否設(shè)計(jì)不當(dāng)引起的。對于一些復(fù)雜SQL可以考慮使用程序?qū)崿F(xiàn)。USER_TAB_COMMENTS數(shù)據(jù)字典Commenton可加注解高效性防止In子句使用In或notIn子句時(shí),特別是當(dāng)子句中有多個(gè)值時(shí),且查詢數(shù)據(jù)表數(shù)據(jù)較多時(shí),速度會(huì)明顯下降。可以采用連接查詢或外連接查詢來提高性能。Char比varchar查詢時(shí)高效。在進(jìn)行查詢及建立索引時(shí),char比varchar的效率要高,當(dāng)然varchar在存儲(chǔ)上比char要好。防止嵌套的Select子句這個(gè)實(shí)際上是In子句的特例。防止使用Select*語句如果不是必要取出所有數(shù)據(jù),不要用*來代替,應(yīng)給出字段列表,注:不含selectcount(*)。防止不必要的排序不必要的數(shù)據(jù)排序大大的降低系統(tǒng)性能。健壯性Insert語句使用Insert語句一定要給出要插入值的字段列表,這樣即使更改了表結(jié)構(gòu)加了字段也不會(huì)影響現(xiàn)有系統(tǒng)的運(yùn)行。Count(*)、Count(id)、count(distinctid)的區(qū)別Selectcount(*)fromtesttab得到表testtab的記錄數(shù)selectcount(id)fromtesttab得到表testtabid字段非空記錄數(shù)selectcount(distinctid)fromtesttab得到表testtabid字段值非相同記錄數(shù)Notnull為字段類型性質(zhì)的約束本約束功能在后期無語法使期失效,可使用修改字段類型方式。altertablemodify字段名類型notnullaltertablemodify字段名類型外鍵值可用null的問題外鍵列如沒有明確說明notnull,可插入null記錄〔而null是在外部表的記錄中沒有的〕,如無可插null記錄的想法,要對外鍵字段加notnull約束。序列sequence跳號(hào)的問題sequence因回滾,系統(tǒng)崩潰〔使用cache內(nèi)的值將認(rèn)為已用〕,多表引用都將使其跳號(hào),所以不能用于為連續(xù)序號(hào)utl_row.cast_to_rowunicn\intersect\minus使用ordeyby的考前須知以上語句進(jìn)行連表操作,而表同表的字段順序的類型相同但字段標(biāo)題名可不同,使用ordeyby時(shí)后面如果是字段名,要求所有的表的字段標(biāo)題名相同,否那么用字段的順序號(hào)selectid,name,yearfromuser1unionselectno,name,to_number(null)yearfromuser2orderby1,name,year平安性無論在使用Select,還是使用破壞力極大的Update和Delete語句時(shí),一定要檢查Where條件判斷的完整性,不要在運(yùn)行時(shí)出現(xiàn)數(shù)據(jù)的重大喪失。如果不確定,最好先用Select語句帶上相同條件來驗(yàn)證一下結(jié)果集,來檢驗(yàn)條件是否正確。完整性有依賴關(guān)系的表,例如主外鍵關(guān)系表,在刪除父表時(shí)必須級(jí)聯(lián)刪除其子表相應(yīng)數(shù)據(jù),或那么按照某種業(yè)務(wù)規(guī)那么轉(zhuǎn)移該數(shù)據(jù)。9I中表中字段縮小及變類型,字段為空或表空,varchar和char長度不變可任意改,字段名和表名可字段可用ALTERTABLEtableSETUNUSED(column)設(shè)定為不可用,注意無命令再設(shè)為可用。備份恢復(fù)設(shè)計(jì)原那么數(shù)據(jù)庫exp/imp備份恢復(fù)Oracle數(shù)據(jù)庫的Exp、Imp提供了數(shù)據(jù)快速的備份和恢復(fù)手段,提供了數(shù)據(jù)庫級(jí)、用戶級(jí)和表級(jí)的數(shù)據(jù)備份恢復(fù)方式。這種方法一般作為數(shù)據(jù)庫輔助備份手段。數(shù)據(jù)庫級(jí)備份原那么在數(shù)據(jù)庫的數(shù)據(jù)量比擬小,或數(shù)據(jù)庫初始建立的情況下采用。不適合7*24的在線生產(chǎn)環(huán)境數(shù)據(jù)庫備份。用戶級(jí)備份原那么在用戶對象表數(shù)據(jù)容量比擬小、或那么用戶對象初始建立的情況下使用。表級(jí)備份原那么主要在以下場合采用的備份方式:參數(shù)表備份、靜態(tài)表備份、分區(qū)表的分區(qū)備份。數(shù)據(jù)庫冷備份原那么數(shù)據(jù)庫冷備份必須符合以下原那么:數(shù)據(jù)庫容量比擬小。數(shù)據(jù)庫允許關(guān)閉的情況。Rman備份恢復(fù)原那么這種方式適用于7*24環(huán)境下的聯(lián)機(jī)熱備份情形。Catalog數(shù)據(jù)庫單獨(dú)建立備份恢復(fù)用的數(shù)據(jù)庫實(shí)例,盡可能與生產(chǎn)環(huán)境的數(shù)據(jù)庫分開,確保catalog與生產(chǎn)數(shù)據(jù)庫的網(wǎng)絡(luò)連接良好。在9I系統(tǒng)使用良好的備份策略以可,支持完全使用控制文件保存catalog信息,備份策略如下:backupspfileformat'/data/backup/%d_SPFILE_%T_%s_%p.bak';sql"altersystemarchivelogcurrent";backuparchivelogallformat'/data/backup/%d_ARC_%T_%s_%p.bak'deleteallinput;backupcurrentcontrolfileformat'/data/backup/%d_CTL_%T_%s_%p.bak';在spfile、控制文件、數(shù)據(jù)庫全丟的情況下可通過下面的方式恢復(fù)RMAN>connecttargetconnectedtotargetdatabase(notstarted)RMAN>startupRMAN>restorespfilefrom'/data/backup/COMMDB_SPFILE_20030411_9_1.bak';SQL>startupORA-00205:errorinidentifyingcontrolfile,checkalertlogformoreinfoRMAN>restorecontrolfilefrom'd:\DB92_CTL_20031113_9_1.BAK';Moutdatabase:RMAN>recoverdatabase;RMAN>alterdatabaseopenresetlogs;注意:對數(shù)據(jù)庫設(shè)定控制文件保存?zhèn)浞菪畔?65天,具體語句如下。altersystemsetcontrol_file_record_keep_time=365SCOPE=BOTH;ArchiveLog設(shè)置ArchiveLog的位置,確保存儲(chǔ)介質(zhì)有足夠的空間來保存指定時(shí)間內(nèi)archivelog的總量。建設(shè)定期對RMAN進(jìn)行全備份,刪除冗余歸檔日志文件。全備份策略對于小容量數(shù)據(jù)庫,可以采用全備份策略。對于大容量數(shù)據(jù)庫,必須制定全備份策略方案,備份時(shí)對archivelog進(jìn)行轉(zhuǎn)儲(chǔ),同時(shí)冷備份catalog數(shù)據(jù)庫。增量備份策略對于大容量數(shù)據(jù)庫,必須制定增量備份、累積備份和全備份的周期,備份時(shí)對archivelog進(jìn)行轉(zhuǎn)儲(chǔ),同時(shí)冷備份catalog數(shù)據(jù)庫?;謴?fù)原那么采用Rman腳本進(jìn)行數(shù)據(jù)庫恢復(fù)。數(shù)據(jù)庫恢復(fù)有以下幾種:局部恢復(fù)主要用于恢復(fù)表空間、數(shù)據(jù)文件,一般不影響數(shù)據(jù)庫其他操作。完全恢復(fù)數(shù)據(jù)庫恢復(fù)到故障點(diǎn),由catalog當(dāng)前數(shù)據(jù)庫決定。不完全恢復(fù)恢復(fù)到數(shù)據(jù)庫的某一時(shí)間點(diǎn)或備份點(diǎn)?;謴?fù)catalog數(shù)據(jù)庫?;謴?fù)數(shù)據(jù)庫controlfile?;謴?fù)到數(shù)據(jù)庫某一時(shí)間點(diǎn)。重設(shè)日志序列。備用數(shù)據(jù)庫原那么數(shù)據(jù)庫系統(tǒng)在以下情況下可以考慮采用備用數(shù)據(jù)庫dataguard原那么:數(shù)據(jù)庫容量適中。數(shù)據(jù)庫嚴(yán)格要求7*24不間斷,或間斷時(shí)間要求控制在最小范圍內(nèi)。數(shù)據(jù)庫要求有異地備份冗余。一些小經(jīng)驗(yàn)使用oemc的oms時(shí),首選項(xiàng)要求是節(jié)點(diǎn)和數(shù)據(jù)庫分別參加系統(tǒng)用戶〔如:administrator〕和數(shù)據(jù)庫DBA用戶(system)。節(jié)點(diǎn)的系統(tǒng)用戶必須有批處理作業(yè)登錄的權(quán)限。agent不能啟動(dòng),lisnter修改后都要手動(dòng)刪除oracle\ora9\network\agent中的*.q文件。oracle\admin\my9i\bdump中是用戶的出錯(cuò)日志。改變表的空間的方式altertablehr.ssssmoveTABLESPACEexample〔要重建索引〕;或用imp導(dǎo)入時(shí),設(shè)定導(dǎo)入用戶只有某一表空間的使用權(quán),無RESOURCE角色和UNLIMITEDTABLESPACE權(quán)限。aletersystemsetlog_checkpoint_to_alter=true,后可報(bào)警文件發(fā)現(xiàn)checkpoint的起動(dòng)和結(jié)束時(shí)間。系統(tǒng)調(diào)優(yōu)知識(shí)生成狀態(tài)報(bào)表〔statspack的使用〕使用〔存放位置@?\rdbms\admin\〕的文件生成報(bào)表用戶。@?\rdbms\admin\Spcreate.sql建表。將timed_statistics設(shè)定true。使用生成的perfstat用戶登錄,執(zhí)行以下語句手動(dòng)收集信息。Exexstatspack.snapExecstatspack.snap(I_SNAP_LEVEL=>0,I_MODEFY_PRAMETER=>TRUE)0級(jí),最少10最大。使用下面的語句生成狀態(tài)報(bào)表:@?\rdbms\admin\Spreport.sql其他相關(guān)文件deletestats$snapshot;清原來記錄數(shù)據(jù)@?\rdbms\admin\Saputo.sqlselectjobfromuser_jobs取用戶作業(yè)號(hào)execdbms_remove(作業(yè)號(hào))timed_statistics=true要求@?\rdbms\admin\spdrop.sql;sql追蹤設(shè)定全部用戶跟蹤altersystemsetsql_trace=true;用戶級(jí)別跟蹤altersessionsetsql_trace=true;用戶的跟蹤文件生成在admin\{pid}\udump\{pid}_ora_{SPID}.trc中,spid從下面語句得到SELECTbkpr,s.username,p.spid,s.sid,s.serial#FROMv$bgprocessb,v$sessions,v$processpWHEREp.addr=b.paddr(+)ANDp.addr=s.paddrands.username=user;DBA對特定用戶跟蹤execdbms_system_set_Sql_trace_in_session(sid,serial#,true)信息從下面得到SELECTbkpr,s.username,p.spid,s.sid,s.serial#,osuser,gramFROMv$bgprocessb,v$sessions,v$processpWHEREp.addr=b.paddr(+)ANDp.addr=s.paddr;/*p.spid用于sql_trace時(shí)日志編號(hào),dbms_system.set_sql_trace_in_session(sid,erial#,true)*/用戶的跟蹤文件生成在admin\{pid}\udump中系統(tǒng)的跟蹤文件生成在admin\{pid}\bdump\alert_{pid}.logtkprof.exe將log文件生成格式化文本在avRd(ms)20以上說明表空間使用過用頻繁,考慮將表分開其他表空間上系統(tǒng)變量fast_start_mttr_target的值要大到不產(chǎn)生log等待,當(dāng)然也可通過加log組使其不等待reaolog大小應(yīng)為每30分鐘切換一次建議表空間的利用率不超80%bufferhit要達(dá)80%以上為好內(nèi)存調(diào)整一般的內(nèi)存分配原那么SGA50%〔其中80%DATABUFFER,15%SHAREPOOL,5其他〕PGA30%OS20%例如:2G的WINDOWS的平臺(tái),OS300M,SAG1.2G,PGA500M內(nèi)存分配的根本單位SGA《=128M4MSGA》128M64位系統(tǒng)16M,32M系統(tǒng)8M動(dòng)態(tài)分配時(shí)總值不可大于sga_max_size通過V$SGA_DYNAMIC_FREE_MEMORY取空閑內(nèi)存空間在縮小時(shí)如果內(nèi)存空間實(shí)際在應(yīng)用中,CPU利用率將達(dá)100%,最后將語句出錯(cuò)。V$SGASTAT可看實(shí)際的使用情況Redologbuffer一般在5M內(nèi),可通過v$sessuon_wait看是否等,v$sysstat可也通過報(bào)警文件看是否等切換,方法可加組。可通過nologging〔數(shù)據(jù)庫也要設(shè)定支持nologging〕方法減少日志文件產(chǎn)生量。java_pool沒有設(shè)定時(shí),使用shared_pool_sizeshared_pool本緩沖區(qū)用于sql語句,plsql等的對象保存Cursor_sharing{Exact|Similar|force}游標(biāo)共享設(shè)定Force方式適用OLTP數(shù)據(jù)庫,Exact方式適合數(shù)據(jù)倉庫,similar為智能方式hardparses硬SQL語句分析,每秒要底于100次,小要加大shared_poolsoftparse軟SQL語句分析,OLTP要達(dá)90%以上,小要加大shared_pool不建議用無命名PLSQL段如果有大PLSQL(存儲(chǔ)過程)對象可強(qiáng)制保存于內(nèi)存,也可加大SHARED_POOL_RESERVED_SIZE,大小不可過SHARED_POOL_SIZE的50%,不然實(shí)例不能起動(dòng)db_cache本緩沖區(qū)用于數(shù)據(jù)庫數(shù)據(jù)對象保存db_cache_advice為on,可以提出通過企業(yè)管理器看到系統(tǒng)建議通過select*fromv$system_event進(jìn)行系統(tǒng)查看。發(fā)現(xiàn)存在freebufferwaits

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論