所謂第一正規化(1nf)是指資料庫表的每一列都是不可分割的基本資料項,同一列中不能有多個值,即實體中的某個屬性不能有多個值或者不能有重複的屬性。如果出現重複的屬性,就可能需要定義乙個新的實體,新的實體由重複的屬性構成,新實體與原實體之間為一對多關係。在第一正規化(1nf)中表的每一行只包含乙個例項的資訊。例如,對於圖3-2 中的員工資訊表,不能將員工資訊都放在一列中顯示,也不能將其中的兩列或多列在一列中顯示;員工資訊表的每一行只表示乙個員工的資訊,乙個員工的資訊在表中只出現一次。簡而言之,第一正規化就是無重複的列。
第二正規化(2nf)是在第一正規化(1nf)的基礎上建立起來的,即滿足第二正規化(2nf)必須先滿足第一正規化(1nf)。第二正規化(2nf)要求資料庫表中的每個例項或行必須可以被惟一地區分。為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。如圖3-2 員工資訊表中加上了員工編號(emp_id)列,因為每個員工的員工編號是惟一的,因此每個員工可以被惟一區分。這個惟一屬性列被稱為主關鍵字或主鍵、主碼。
第二正規化(2nf)要求實體的屬性完全依賴於主關鍵字。所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那麼這個屬性和主關鍵字的這一部分應該分離出來形成乙個新的實體,新實體與原實體之間是一對多的關係。為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。簡而言之,第二正規化就是非主屬性非部分依賴於主關鍵字。
滿足第三正規化(3nf)必須先滿足第二正規化(2nf)。簡而言之,第三正規化(3nf)要求乙個資料庫表中不包含已在其它表中已包含的非主關鍵字資訊。例如,存在乙個部門資訊表,其中每個部門有部門編號(dept_id)、部門名稱、部門簡介等資訊。那麼在圖3-2的員工資訊表中列出部門編號後就不能再將部門名稱、部門簡介等與部門有關的資訊再加入員工資訊表中。如果不存在部門資訊表,則根據第三正規化(3nf)也應該構建它,否則就會有大量的資料冗餘。簡而言之,第三正規化就是屬性不依賴於其它非主屬性。
事務是使用者定義的乙個資料庫操作序列,這些操作要麼全做要麼不全做,是乙個不可分割的工作單位。例如,在關聯式資料庫中,乙個事務可以是一條sql語句,一組sql語句或者整個程式。
事務的開始和結束可以由使用者顯示控制。如果使用者沒有顯示的定義事務,則有dbms按照預設規定自動劃分事務。在sql中定義事務的語句有三條:
begin transaction—事務的開始;
commit—表示提交,即提交事務的所有操作。就是說將事務中所有對資料庫的更新寫回到磁碟上的物理資料庫中去,事務正常結束。
rollback—表示回滾,即在事務執行的過程中發生了某種故障,事務不能繼續執行,系統將事務中對資料庫的所有已經完成的操作全部撤銷,回滾到事務開始的狀態。
四個特性:
(1)原子性(atomicity),它是資料庫的邏輯單位,要麼全做,要麼全部做;
(2)一致性(consistency),事務的執行結果必須是使資料庫從乙個一致性狀態變到另乙個一致性狀態。比如說,某公司的再銀行中有a,b兩個賬號,現在存a中取1萬元錢存入b賬號中,則a賬戶減掉1萬元,b賬戶增加一萬元。這兩個操作要麼全做,要麼全部做。
(3)隔離性(isolation),乙個事務的操作不會被其他事務打擾。即乙個事務的內部操作及使用的資料對其他併發事務是隔離的,併發執行的各個事務之間不能相互干擾。
(4)持續性(durability),指乙個事務一旦提交,它對資料庫中資料的改變應該是永久性的。
資料庫事務和正規化理解
學習自用.網上大把資料,主要為了貼上自己理解.老實說標題和內容真難對的上.以後再修改下.2020年7月23日已改 事務的acid 每項事務 的全部操作,要麼做了就成功,要麼就失敗了全部回滾,而不會存在中間狀態.回滾通過undo log來實現,為什麼要有這個概念的,有什麼資料庫的原子性的反例嗎 und...
資料庫正規化 事務 鎖學習
資料庫三大正規化 1 第一正規化 保證每列的原子性,不能再拆分,比如 能拆成使用者名稱和手機,就不要合在一起 2 第二正規化 保證每列都和主鍵關聯 3 第三正規化 保證每列都和主鍵直接相關,而不是間接相關,這個涉及到拆分欄位到其他表,主表只顯示其他表主鍵資訊。資料庫事務 1 原子性 要麼都執行,要麼...
資料庫 資料庫正規化
關聯式資料庫的設計規範。不同的規範要求被稱為不同的正規化,越高的正規化資料庫冗餘越小。減少資料庫中資料冗餘的過程 1 第一正規化 1nf 在關係模式r中,當且僅當所有屬性只包含原子值,即每個分量都是不可再分的資料項,則稱r滿足1nf。例如表所示的教師職稱情況關係就不滿足1nf。原因在於,該關係模式中...