一、database schema 和database instance的區(qū)別
schema是數(shù)據(jù)庫(kù)的組織和結(jié)構(gòu),包含了表、列、數(shù)據(jù)類(lèi)型、視圖、存儲(chǔ)過(guò)程等。schema可以理解為是一個(gè)描述數(shù)據(jù)的數(shù)據(jù),它的概念更多是在database設(shè)計(jì)過(guò)程中提及,顯示了數(shù)據(jù)庫(kù)對(duì)象及其相互之間的關(guān)系,相較于instance而言,schema不會(huì)經(jīng)常改變。而instance 是某一特定時(shí)刻內(nèi),數(shù)據(jù)庫(kù)中的數(shù)據(jù),隨著數(shù)據(jù)的更新而被創(chuàng)建的。
schema是數(shù)據(jù)庫(kù)模式,包括物理模式、邏輯模式和視圖模式;
instance是數(shù)據(jù)庫(kù)實(shí)例,是數(shù)據(jù)庫(kù)中某一時(shí)刻存儲(chǔ)的數(shù)據(jù)。
數(shù)據(jù)庫(kù)模式定義了屬于特定數(shù)據(jù)庫(kù)的表中的變量聲明;這些變量在某一時(shí)刻的值稱為該數(shù)據(jù)庫(kù)的實(shí)例。
database 和 schema 之間的基本區(qū)別是 database 定期操作而 schema 不經(jīng)常更改。schema 是數(shù)據(jù)庫(kù)的結(jié)構(gòu)定義,而數(shù)據(jù)庫(kù)是組織和相互關(guān)聯(lián)的數(shù)據(jù)的集合。
database 有 schema 和表的記錄,但 schema 包括表、屬性名稱、屬性類(lèi)型、約束等。DDL(數(shù)據(jù)定義語(yǔ)言)語(yǔ)句用于生成和修改 schema,而 DML(數(shù)據(jù)操作語(yǔ)言)用于數(shù)據(jù)庫(kù)中的數(shù)據(jù)操作。schema 不使用內(nèi)存進(jìn)行存儲(chǔ),但 database 使用。
延伸閱讀:
二、什么是數(shù)據(jù)庫(kù)
有組織且相互關(guān)聯(lián)的數(shù)據(jù)的集合稱為數(shù)據(jù)庫(kù)。database 是一個(gè)存儲(chǔ)數(shù)據(jù)的應(yīng)用程序。它有各種應(yīng)用程序,包括 MySQL、Microsoft SQL、Oracle 等。
每個(gè)數(shù)據(jù)庫(kù)都不同,因?yàn)槊總€(gè)公司/組織都有其結(jié)構(gòu)、數(shù)據(jù)類(lèi)型和約束。數(shù)據(jù)庫(kù) 會(huì)定期更新,以獲取有關(guān)公司的最新數(shù)據(jù)。
數(shù)據(jù)庫(kù)可以手動(dòng)和數(shù)字方式維護(hù)。在這個(gè)數(shù)據(jù)無(wú)處不在的時(shí)代,數(shù)字?jǐn)?shù)據(jù)庫(kù)是優(yōu)選和使用。數(shù)據(jù)庫(kù)的大小取決于組織的數(shù)據(jù)和需求。