優化資料庫設計

2021-07-25 18:32:18 字數 1246 閱讀 2878

資料庫設計步驟:

1.需求分析

1.收集資訊

2.標識實體

1.標識實體的屬性

2.標識實體的關係

2.繪製e-r圖(e:實體r:關係)

3.繪製資料庫模型圖

4.根據sql行程資料庫

第一、二、三正規化

1 第一正規化(1nf)無重複的列

所謂第一正規化(1nf)是指資料庫表的每一列都是不可分割的基本資料項,同一列中不能有多個值,即實體中的某個屬性不能有多個值或者不能有重複的屬性。

如果出現重複的屬性,就可能需要定義乙個新的實體,新的實體由重複的屬性構成,新實體與原實體之間為一對多關係。

在第一正規化(1nf)中表的每一行只包含乙個例項的資訊。

簡而言之,第一正規化就是無重複的列。

說明:在任何乙個關聯式資料庫中,第一正規化(1nf)是對關係模式的基本要求,不滿足第一正規化(1nf)的資料庫就不是關聯式資料庫。 

2 第二正規化(2nf)屬性完全依賴於主鍵[消除部分子函式依賴] 

第二正規化(2nf)是在第一正規化(1nf)的基礎上建立起來的,即滿足第二正規化(2nf)必須先滿足第一正規化(1nf)。

第二正規化(2nf)要求資料庫表中的每個例項或行必須可以被惟一地區分。為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。

例如員工資訊表中加上了員工編號(emp_id)列,因為每個員工的員工編號是惟一的,因此每個員工可以被惟一區分。

這個惟一屬性列被稱為主關鍵字或主鍵、主碼。 

第二正規化(2nf)要求實體的屬性完全依賴於主關鍵字。

所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那麼這個屬性和主關鍵字的這一部分應該分離出來形成乙個新的實體,新實體與原實體之間是一對多的關係。

為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。

簡而言之,第二正規化就是屬性完全依賴於主鍵。 

3 第三正規化(3nf)屬性不依賴於其它非主屬性[消除傳遞依賴]

滿足第三正規化(3nf)必須先滿足第二正規化(2nf)。

簡而言之,第三正規化(3nf)要求乙個資料庫表中不包含已在其它表中已包含的非主關鍵字資訊。

例如,存在乙個部門資訊表,其中每個部門有部門編號(dept_id)、部門名稱、部門簡介等資訊。

那麼在的員工資訊表中列出部門編號後就不能再將部門名稱、部門簡介等與部門有關的資訊再加入員工資訊表中。

如果不存在部門資訊表,則根據第三正規化(3nf)也應該構建它,否則就會有大量的資料冗餘。

簡而言之,第三正規化就是屬性不依賴於其它非主屬性。 

資料庫優化 資料庫設計優化

一 索引優化 1.首先索引不是越多越好,要視情況而定。因為索引會降低insert和update的效率 insert和update有時可能會重建索引。2.乙個表的索參數量最好不要超過6個,擇優而建。3.專案上線後,根據使用者的查詢條件字段稍微調整資料庫中的字段索引。二 分表 1.縱切 根據表字段來且分...

mysql資料庫設計優化

1 選取最適用的字段屬性 1 資料庫中的表越小,查詢效率越高,所以將表中字段的寬度設計的盡可能小 2 字段設定為not null,減少比較null值 3 對於省份與性別等,可定義為enum型別 數值型資料,處理速度比文字型別快 2 適用連線 join 代替子查詢 sub queries 使用join...

優化MySchool資料庫設計

use master go if exists select from sysdatabases where name myschool drop database myschool create database z on primary name z filename e zl.mdf size...