亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

優化Oracle庫表設計的若干方法

2024-08-29 14:01:32
字體:
來源:轉載
供稿:網友
    前言

  絕大多數的Oracle數據庫性能問題都是由于數據庫設計不合理造成的,只有少部分問題根植于Database Buffer、Share Pool、Redo Log Buffer等內存模塊配置不合理,I/O爭用,CPU爭用等DBA職責范圍上。所以除非是面對一個業已完成不可變更的系統,否則我們不應過多地將關注點投向內存、I/O、CPU等性能調整項目上,而應關注數據庫表本身的設計是否合理,庫表設計的合理性才是程序性能的真正執牛耳者。
合理的數據庫設計需要考慮以下的方面:

  ?業務數據以何種方式表達。如一個員工有多個Email,你可以在T_EMPLOYEE表中建立多個Email字段如email_1、email_2、email_3,也可以創建一個T_EMAIL子表來存儲,甚至可以用逗號分隔開多個Email地址存放在一個字段中。

  ?數據以何種方式物理存儲。如大表的分區,表空間的合理設計等。

  ?如何建立合理的數據表索引。表索引幾乎是提高數據表查詢性能最有效的方法,Oracle擁有類型豐富的數據表索引類型,如何取舍選擇顯得特別重要。

  本文我們將目光主要聚焦于數據表的索引上,同時也將提及其他兩點的內容。通過對一個簡單的庫表設計實例的分析引出設計中的不足,并逐一改正??紤]到手工編寫庫表的SQL腳本原始且低效,我們將用目前最流行的庫表設計工具PowerDesigner 10來講述表設計的過程,所以在本文中你還會了解到一些相關的PowerDesigner的使用技巧。

  一個簡單的例子

  某個開發人員著手設計一個訂單的系統,這個系統中有兩個主要的業務表,分別是訂單基本信息表和訂單條目表,這兩張表具有主從關系的表,其中T_ORDER是訂單主表,而T_ORDER_ITEM是訂單條目表。數據庫設計人員的設計成果如圖 1所示:


圖 1 訂單主從表


  ORDER_ID是訂單號,為T_ORDER的主鍵,通過名為SEQ_ORDER_ID的序列產生鍵值,而ITEM_ID是T_ORDER_ITEM表的主鍵,通過名為SEQ_ORDER_ITEM的序列產生鍵值,T_ORDER_ITEM通過ORDER_ID外鍵關聯到T_ORDER表。

  需求文檔指出訂單記錄將通過以下兩種方式來查詢數據:

  ?CLIENT + ORDER_DATE+IS_SHPPED:根據"客戶+訂貨日期+是否發貨"條件查詢訂單及訂單條目。

  ?ORDER_DATE+IS_SHIPPED:根據"訂貨日期+是否發貨"條件查詢訂單及訂單條目。

  數據庫設計人員根據這個要求,在T_ORDER表的CLIENT、 ORDER_DATE及IS_SHPPED三字段上建立了一個復合索引IDX_ORDER_COMPOSITE;在T_ORDER_ITEM為外鍵ORDER_ID建立IDX_ORDER_ITEM_ORDER_ID索引。

  讓我們看一下該份設計的最終SQL腳本:

/*訂單表*/
create table T_ORDER (
  ORDER_ID NUMBER(10) not null,
  ADDRESS VARCHAR2(100),
  CLIENT VARCHAR2(60),
  ORDER_DATE CHAR(8),
  IS_SHIPPED CHAR(1),
  constraint PK_T_ORDER primary key (ORDER_ID)
);

create index IDX_CLIENT on T_ORDER (
 CLIENT ASC,
 ORDER_DATE ASC,
 IS_SHIPPED ASC);

/*訂單條目子表*/

create table T_ORDER_ITEM (
 ITEM_ID NUMBER(10) not null,
 ORDER_ID NUMBER(10),
 ITEM VARCHAR2(20),
 COUNT NUMBER(10),
 constraint PK_T_ORDER_ITEM primary key (ITEM_ID)
);

create index IDX_ORDER_ITEM_ORDER_ID on T_ORDER_ITEM (
 ORDER_ID ASC);
 alter table T_ORDER_ITEM add constraint FK_T_ORDER__REFERENCE_T_ORDER foreign key (ORDER_ID) references T_ORDER (ORDER_ID);

  我們承認在ER關系上,這份設計并不存在的缺陷,但卻存在以下有待優化的地方:

  ?沒有將表數據和索引數據存儲到不同的表空間中,而不加區別地將它們存儲到同一表空間里。這樣,不但會造成I/O競爭,也為數據庫的維護工作帶來不便。

  ?ORACLE會自動為表的主鍵列創建一個普通B-Tree索引,但由于這兩張表的主鍵值都通過序列提供,具有嚴格的順序性(升序或降序),此時手工為其指定一個反鍵索引(reverse key index)將更加合理。

  ?在子表T_ORDER_ITEM外鍵列ORDER_ID上建立的IDX_ORDER_ITEM_ORDER_ID的普通B-Tree索引非常適合設置為壓縮型索引,即建立一個壓縮型的B-Tree索引。因為一份訂單會對應多個訂單條目,這就意味著T_ORDER_ITEM表存在許多同值的ORDER_ID列值,通過將其索引指定為壓縮型的B-Tree索引,不但可以減少IDX_ORDER_ITEM_ORDER_ID所需的存儲空間,還將提高表操作的性能。

  ?企圖僅通過建立一個包含3字段IDX_ORDER_COMPOSITE復合索引滿足如前所述的兩種查詢條件方式的索引是有問題的,事實上使用ORDER_DATE+IS_SHIPPED復合條件的查詢將利用不到IDX_ORDER_COMPOSITE索引。
優化設計

  1、將表數據和索引數據分開表空間存儲

  1.1 表數據和索引為何需要使用獨立的表空間

  Oracle強烈建立,任何一個應用程序的庫表至少需要創建兩個表空間,其中之一用于存儲表數據,而另一個用于存儲表索引數據。因為如果將表數據和索引數據放在一起,表數據的I/O操作和索引的I/O操作將產生影響系統性能的I/O競爭,降低系統的響應效率。將表數據和索引數據存放在不同的表空間中(如一個為APP_DATA,另一個為APP_IDX),并在物理層面將這兩個表空間的數據文件放在不同的物理磁盤上,就可以避免這種競爭了。

  擁有獨立的表空間,就意味著可以獨立地為表數據和索引數據提供獨立的物理存儲參數,而不會發生相互影響,畢竟表數據和索引數據擁有不同的特性,而這些特性又直接影響了物理存儲參數的設定。

  此外,表數據和索引數據獨立存儲,還會帶來數據管理和維護上的方面。如你在遷移一個業務數據庫時,為了降低數據大小,可以只遷出表數據的表空間,在目標數據庫中通過重建索引的方式就可以生成索引數據了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩国产精品一区| 日韩h在线观看| 91av在线网站| 欧美亚洲国产视频| 日韩在线激情视频| 中文字幕日韩精品在线| 亚洲精品日韩激情在线电影| 亚洲美女精品成人在线视频| 日韩欧美一区二区三区久久| 国产精品老女人精品视频| 91美女片黄在线观看游戏| 热门国产精品亚洲第一区在线| 福利一区视频在线观看| 久久久久久网址| 国产一区二区三区直播精品电影| 欧美性受xxxx白人性爽| 亚洲综合中文字幕在线观看| 亚洲成人网在线观看| 国产婷婷成人久久av免费高清| 亚洲国产精品va在线观看黑人| 精品国产依人香蕉在线精品| 午夜免费在线观看精品视频| 午夜精品久久久久久久男人的天堂| 国产精品久久综合av爱欲tv| 91久久精品美女| 日韩在线精品视频| 亚洲的天堂在线中文字幕| 色偷偷综合社区| 日韩av电影免费观看高清| 日韩欧美在线观看视频| 久久久久久久国产| 91最新在线免费观看| 中日韩午夜理伦电影免费| 97人人爽人人喊人人模波多| 日韩中文字幕免费视频| 91精品久久久久久久久久| 久久成人18免费网站| 性欧美在线看片a免费观看| 日本精品久久中文字幕佐佐木| 国产精品影院在线观看| 精品人伦一区二区三区蜜桃免费| 久久久久亚洲精品成人网小说| 久久男人av资源网站| 第一福利永久视频精品| 中文字幕国产亚洲2019| 69国产精品成人在线播放| 欧美精品videossex88| 国产精品久久久久久中文字| 日韩亚洲欧美中文高清在线| 精品国产一区二区在线| 91免费电影网站| 欧美亚洲免费电影| 久久久免费观看| 亚洲午夜国产成人av电影男同| 尤物tv国产一区| 欧美日韩亚洲精品内裤| 色悠悠国产精品| 日韩欧美视频一区二区三区| 久久久久久久爱| 国产成人+综合亚洲+天堂| www高清在线视频日韩欧美| 国产成人精品日本亚洲| 色婷婷综合久久久久中文字幕1| 日韩在线视频观看| 亚洲福利视频二区| 国产精品丝袜高跟| 欧美风情在线观看| 亚洲一区二区久久久久久| 日本亚洲精品在线观看| 国产精品欧美亚洲777777| 亚洲最大成人免费视频| 海角国产乱辈乱精品视频| 日韩高清免费观看| 亚洲人成绝费网站色www| 日韩美女视频中文字幕| 精品少妇一区二区30p| 亚洲精品久久久久中文字幕二区| 国产精品露脸自拍| 日本一区二三区好的精华液| 亚洲欧洲偷拍精品| 日韩成人网免费视频| 在线成人激情黄色| 日韩美女在线观看一区| 国产日韩欧美在线播放| **欧美日韩vr在线| 亚洲一区二区三区四区在线播放| 97国产精品免费视频| 国产精品揄拍500视频| 91国内揄拍国内精品对白| 亚洲福利视频免费观看| 国产午夜精品全部视频在线播放| 欧美影院久久久| 国产视频自拍一区| 久久成人精品电影| 久久久免费高清电视剧观看| 欧美国产精品人人做人人爱| 2019中文字幕免费视频| 久久久精品久久久| 亚洲一区亚洲二区| 国产欧美精品一区二区三区-老狼| 日韩福利视频在线观看| 欧美肥臀大乳一区二区免费视频| 欧美另类老女人| 精品久久久久久久久久ntr影视| 国产精品日日做人人爱| 成人在线精品视频| 亚洲综合精品一区二区| 国产深夜精品福利| 一区二区三区国产在线观看| 亚洲人成电影网| 这里只有精品视频在线| 久久99久久99精品免观看粉嫩| 日韩网站免费观看高清| 成人羞羞国产免费| 亚洲伊人成综合成人网| 欧美人交a欧美精品| 久久九九全国免费精品观看| 久久久国产精品免费| yw.139尤物在线精品视频| 日韩欧美一区二区三区久久| 欧洲日本亚洲国产区| 亚洲一级黄色片| 欧美丝袜一区二区| 亚洲第一福利网站| 欧美日韩国产一中文字不卡| 国产va免费精品高清在线观看| 日韩美女中文字幕| 中文字幕日韩高清| 日韩av中文字幕在线播放| 欧美激情极品视频| 国产一区二区三区视频免费| 国产精品丝袜久久久久久不卡| 亚洲999一在线观看www| 亚洲最大福利视频网| 色综合视频一区中文字幕| 国产欧美一区二区三区四区| 久久久人成影片一区二区三区| 亚洲欧洲国产一区| 超碰97人人做人人爱少妇| 国产日产久久高清欧美一区| 久久精品国产成人| 尤物yw午夜国产精品视频| 色综合久久久888| 免费不卡在线观看av| 日韩中文字幕在线精品| 91亚洲精品久久久| 亚洲日本aⅴ片在线观看香蕉| 欧美性受xxxx白人性爽| 亚洲在线观看视频| 日韩一级裸体免费视频| 国产日韩欧美在线| 久久久久久亚洲精品| 亚洲精品一区中文字幕乱码| 2019国产精品自在线拍国产不卡| 久久影院资源站| 亚洲摸下面视频| 亚洲男女自偷自拍图片另类| 亚洲综合av影视| 久久久久久久久久久免费| 成人黄色免费网站在线观看| 日韩在线播放av| 亚洲精品91美女久久久久久久| 九九九久久国产免费| 久久久www成人免费精品|