SQL Server數(shù)據(jù)庫基本概念、組成、常用對象與約束
二、基本概念
1、數(shù)據(jù)庫
數(shù)據(jù)庫(DB):即DataBase的縮寫,是按照一定的數(shù)據(jù)結(jié)構(gòu)來組織、存儲和管理數(shù)據(jù)的一個(gè)倉庫。是存儲在一起的相關(guān)數(shù)據(jù)的一個(gè)集合??梢园褦?shù)據(jù)庫想象成一個(gè)文件柜,文件柜里面又包含有多個(gè)文件夾,而文件夾里面又包含有多個(gè)文件。
數(shù)據(jù)庫根據(jù)作用的不同,又可以分為兩種:
- 關(guān)系型數(shù)據(jù)庫。是建立在關(guān)系模型基礎(chǔ)上的數(shù)據(jù)庫,借助于集合、數(shù)學(xué)等觀念和方法來處理數(shù)據(jù)庫的數(shù)據(jù)。比如SQL Server、MySQL、Access等。
- 非關(guān)系型數(shù)據(jù)庫。非關(guān)系型數(shù)據(jù)庫也被稱為NoSQL數(shù)據(jù)庫,NoSQL的本意是“Not Only SQL”,指的是非關(guān)系型數(shù)據(jù)庫,而不是“NO SQL”的意思。非關(guān)系型數(shù)據(jù)庫的產(chǎn)生不是要徹底否定關(guān)系型數(shù)據(jù)庫,而是作為傳統(tǒng)數(shù)據(jù)庫的一個(gè)有效補(bǔ)充。
2、數(shù)據(jù)庫管理系統(tǒng)
數(shù)據(jù)庫管理系統(tǒng)(DBMS):即DataBase Management System的縮寫,是為了管理數(shù)據(jù)庫而設(shè)計(jì)的一個(gè)電腦軟件系統(tǒng)。是用來操作和管理數(shù)據(jù)庫的大型軟件,用于建立、使用和維護(hù)數(shù)據(jù)庫。它對數(shù)據(jù)庫進(jìn)行統(tǒng)一的管理和控制,以保證數(shù)據(jù)庫的安全性和完整性。用戶可以通過DBMS訪問數(shù)據(jù)庫中的數(shù)據(jù),數(shù)據(jù)庫管理員也可以通過DBMS進(jìn)行數(shù)據(jù)庫的維護(hù)工作。它可以支持多個(gè)應(yīng)用程序和用戶用不同的方法在同時(shí)或不同時(shí)刻去建立、修改和詢問數(shù)據(jù)庫。大部分DBMS提供數(shù)據(jù)定義語言DDL(Data Definition Language)和數(shù)據(jù)操作語言DML(Data Manipulation Language),供用戶定義數(shù)據(jù)庫的模式結(jié)構(gòu)與權(quán)限約束,實(shí)現(xiàn)對數(shù)據(jù)的追加、刪除等操作。
3、數(shù)據(jù)庫系統(tǒng)
數(shù)據(jù)庫系統(tǒng)是由數(shù)據(jù)庫和數(shù)據(jù)庫管理系統(tǒng)組成的。
二、數(shù)據(jù)庫的組成
數(shù)據(jù)庫是以文件的形式存在,由文件和文件組組成的。
1、文件
數(shù)據(jù)庫文件分為以下幾種類型:
- 主要數(shù)據(jù)文件:主要數(shù)據(jù)文件里面存放的是數(shù)據(jù)和數(shù)據(jù)庫的一些初始化信息。每個(gè)數(shù)據(jù)庫有且只有一個(gè)主要數(shù)據(jù)文件。主要數(shù)據(jù)文件以.mdf為擴(kuò)展名。
- 次要數(shù)據(jù)文件:次要數(shù)據(jù)文件里面存放的是除了主要數(shù)據(jù)文件之外的所有數(shù)據(jù)。次要數(shù)據(jù)文件不是必須的,可以沒有。如果有次要數(shù)據(jù)文件,可以有一個(gè)或者多個(gè)。假如數(shù)據(jù)庫的數(shù)據(jù)非常大,這時(shí)候可以把一些數(shù)據(jù)放到次要數(shù)據(jù)文件里面。次要數(shù)據(jù)文件是以.ndf為擴(kuò)展名。
- 事務(wù)日志文件:事務(wù)日志文件存放的是對數(shù)據(jù)庫進(jìn)行操作的所有日志信息。每個(gè)數(shù)據(jù)庫至少要有一個(gè)日志文件,也可以有多個(gè)。事務(wù)日志文件是以.ldf為擴(kuò)展名。
2、文件組
文件組是數(shù)據(jù)庫文件的一種邏輯管理單位,它將數(shù)據(jù)庫文件分成不同的文件組,方便我們對文件的分配和管理。文件組分為以下兩種類型:
- 主文件組(Primary):主要包含主要數(shù)據(jù)文件和沒有明確指派給其它文件組的文件。
- 用戶自定義文件組:我們在使用腳本創(chuàng)建數(shù)據(jù)庫或者修改數(shù)據(jù)庫的時(shí)候,使用fileGroup關(guān)鍵字指定的文件組。
一個(gè)文件只能屬于一個(gè)文件組。
文件組的設(shè)計(jì)原則:
- 文件只能是一個(gè)文件組的成員。
- 文件或文件組只能屬于一個(gè)數(shù)據(jù)庫,不能同時(shí)屬于多個(gè)數(shù)據(jù)庫。
- 數(shù)據(jù)和日志信息不能屬于同一個(gè)文件或文件組。
- 日志文件不能作為文件組的一部分。因?yàn)閿?shù)據(jù)和日志是分開在管理的,所以我們備份的時(shí)候可以只備份數(shù)據(jù)文件或日志文件,恢復(fù)的時(shí)候也可以只恢復(fù)數(shù)據(jù)文件或日志文件,而不用備份整個(gè)數(shù)據(jù)庫。
三、數(shù)據(jù)庫常用對象
這篇文章主要講解數(shù)據(jù)庫中的常用對象。
1、表
表是包含數(shù)據(jù)庫中所有數(shù)據(jù)的對象,由行和列組成,用于組織和存儲數(shù)據(jù)。
2、字段
字段就是表中的列。一個(gè)表中可以有多個(gè)列,也可以只有一個(gè)。
字段也有自己的屬性:列名、數(shù)據(jù)類型(決定了該字段存儲哪種類型的數(shù)據(jù))。
3、視圖
數(shù)據(jù)庫里面可以多張表,表里面可以有多個(gè)字段。表與表之間可能也存在著關(guān)系。視圖也可以認(rèn)為是一張表,但是視圖不是真實(shí)存在的表,是虛擬表。它可以從一張表或者多張表進(jìn)行關(guān)聯(lián)查詢,把需要的字段提取出來,這些字段就會組合成一種虛擬表。是用戶查看數(shù)據(jù)的一種方式。結(jié)構(gòu)和數(shù)據(jù)都是建立在對表的查詢上的。
4、索引
建立索引是為了給用戶提供一種快速訪問數(shù)據(jù)的途徑,索引是依賴于表建立的。我們創(chuàng)建索引是針對于表創(chuàng)建的。創(chuàng)建索引之后,使得我們在遍歷數(shù)據(jù)的時(shí)候,無需對整張表進(jìn)行全面的查詢,而可以通過索引進(jìn)行快速的定位查詢。可以理解為Word文檔里面的目錄。
5、存儲過程
存儲過程是一組為了完成特定功能的SQL語句的集合,存儲過程里面可以只有一條查詢語句也可以有多條,可以是批量的插入操作,還可以有插入、修改、查詢等語句。建立好存儲過程之后,需要對其進(jìn)行生成和編譯,編譯之后就會存儲在數(shù)據(jù)庫之中了。以后使用的時(shí)候,直接對其進(jìn)行調(diào)用即可。存儲過程只需要進(jìn)行一次編譯。
6、觸發(fā)器
屬于用戶自定義的一種SQL事務(wù)命令的集合,可以執(zhí)行多種操作。數(shù)據(jù)庫是針對于表的。當(dāng)對表執(zhí)行增刪改操作時(shí),會自動執(zhí)行觸發(fā)器。
7、約束
約束可以理解為對數(shù)據(jù)表中列值進(jìn)行的一種限制??梢允歉袷缴?、也可以是值范圍的約束。當(dāng)我們對數(shù)據(jù)表的某列定義了這種限制,如果我們在對表進(jìn)行插入數(shù)據(jù)操作的時(shí)候,插入的值不符合這種限制就會阻止插入數(shù)據(jù)??梢愿玫囊?guī)范表中的列。
8、缺省值
缺省值相當(dāng)于對表中的列指定一個(gè)默認(rèn)值。當(dāng)進(jìn)行插入數(shù)據(jù)時(shí),如果沒有為這個(gè)列插入值,那么就會自動以預(yù)先設(shè)置的默認(rèn)值進(jìn)行填充。
四、數(shù)據(jù)庫約束
一、定義
約束:規(guī)定表中的數(shù)據(jù)規(guī)則。如果存在違反約束的數(shù)據(jù)行為,行為就會被阻止。
如果是使用DBMS工具創(chuàng)建表,那么約束必須在創(chuàng)建表之后才能被創(chuàng)建。如果是使用腳本創(chuàng)建表,則可以在腳本中就創(chuàng)建約束。
二、分類
1、主鍵約束
Primary key約束:主鍵約束,具有唯一性、非空,不能被修改。
2、外鍵約束
Foreign key約束:用來加強(qiáng)兩個(gè)表的一列或者多列數(shù)據(jù)之間的連接。首先需要建立主表中的主鍵,然后在定義外鍵表中的外鍵。
注意:只有主表中的主鍵列才能被從表作為外鍵來使用,其它列不可以作為外鍵使用。從表中外鍵的值必須是主表中主鍵的值,主表限制了從表的更新和插入。當(dāng)刪除主表中的某條數(shù)據(jù)時(shí),如果該條數(shù)據(jù)的主鍵在從表中存在引用,那么必須先刪除從表中的引用數(shù)據(jù),然后才能刪除主表中的數(shù)據(jù)。如果該條數(shù)據(jù)在從表中沒有引用,那么可以直接刪除。
3、Unique約束
Unique:唯一性約束。確保表中的一列數(shù)據(jù)沒有相同的值。與主鍵約束相似,但又不同。一個(gè)表的主鍵約束只能有一個(gè),唯一性約束可以有多個(gè),也可以沒有。而且唯一性約束并非是主鍵的一列或多列的組合。唯一鍵可以為null,但主鍵不可以。
4、Check約束
Check約束:我們可以通過邏輯表達(dá)式來判斷數(shù)據(jù)的有效性,用來限制輸入一列或多列的值的范圍。
5、Default約束
Default約束:即默認(rèn)值約束。用戶在插入新的數(shù)據(jù)行時(shí),如果該行沒有指定數(shù)據(jù),那么系統(tǒng)將默認(rèn)值賦給該列。如果沒有設(shè)置默認(rèn)值,系統(tǒng)就會把該列設(shè)置為null值。
到此這篇關(guān)于SQL Server數(shù)據(jù)庫基本概念、組成、常用對象與約束的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SqlServer數(shù)據(jù)庫遠(yuǎn)程連接案例教程
- SQL Server 2014 數(shù)據(jù)庫中文版安裝圖文教程
- SQL Server2012數(shù)據(jù)庫備份和還原的教程
- sqlserver建立新用戶及關(guān)聯(lián)數(shù)據(jù)庫教程
- Windows Server 2016 MySQL數(shù)據(jù)庫安裝配置詳細(xì)安裝教程
- SQL Server附加數(shù)據(jù)庫報(bào)錯(cuò)無法打開物理文件,操作系統(tǒng)錯(cuò)誤5的圖文解決教程
- SQL SERVER數(shù)據(jù)庫表記錄只保留N天圖文教程
- SQL Server 2005恢復(fù)數(shù)據(jù)庫詳細(xì)圖文教程
- sql server 2000數(shù)據(jù)庫備份還原的圖文教程
- sql server 2005數(shù)據(jù)庫備份還原圖文教程
- sql server 2008數(shù)據(jù)庫無法啟動的解決辦法(圖文教程)
相關(guān)文章
SQL update select結(jié)合語句詳解及應(yīng)用
這篇文章主要介紹了SQL update select結(jié)合語句詳解及應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03sql將一個(gè)表中的數(shù)據(jù)插入到另一個(gè)表中的方法
這篇文章主要介紹了sql將一個(gè)表中的數(shù)據(jù)插入到另一個(gè)表中的方法,需要的朋友可以參考下2014-03-03SqlServer存儲過程實(shí)現(xiàn)及拼接sql的注意點(diǎn)
這篇文章主要介紹了SqlServer存儲過程實(shí)現(xiàn)及拼接sql的注意點(diǎn)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07安裝sqlserver2000時(shí)出現(xiàn)wowexec.exe無反應(yīng)的解決方法
wowexec.exe是操作系統(tǒng)相關(guān)程序,用于支持16位進(jìn)程,而wowexec 或者 wowexec.exe則是當(dāng)硬盤上的文件碎片過多時(shí),系統(tǒng)自動進(jìn)行碎片整理2013-04-04select into 和 insert into select 兩種表復(fù)制語句
select into 和 insert into select 兩種表復(fù)制語句,需要的朋友可以參考下。2009-10-10SQL Server數(shù)據(jù)庫中的表名稱、字段比較
這篇文章主要給大家介紹了關(guān)于SQl Server數(shù)據(jù)庫中表名稱、字段比較的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用SQL Server具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09SQLServer觸發(fā)器創(chuàng)建、刪除、修改、查看示例代碼
觸發(fā)器是一種特殊的存儲過程﹐它不能被顯式地調(diào)用﹐而是在往表中插入記錄﹑更新記錄或者刪除記錄時(shí)被自動地激活。所以觸發(fā)器可以用來實(shí)現(xiàn)對表實(shí)施復(fù)雜的完整性約束。2010-06-06