【資料庫概論】第三章 SQL簡述、數據定義和索引

来源:https://www.cnblogs.com/cyra/archive/2023/12/06/17880702.html
-Advertisement-
Play Games

SQL(結構化查詢語言)的演變從IBM的SystemR開始,經過ANSI的標準化,近年來SQL標準變得更加豐富和複雜。SQL的特點包括綜合統一、高度非過程化、面向集合的操作方式以及提供多種使用方式的統一語法結構。在資料庫實例中,基本表獨立存在,而視圖是基本表導出的虛表,用於供人查看。資料庫模式結構包... ...


3.1 SQL概述

3.1.1 產生與發展

最早在IBM的關係資料庫管理系統原型SystemR上實現,後來美國國家標準局(ANSI)批准SQL作為關係資料庫語言的美國標準,同年公佈了SQL標準文本。近些年來SQL標準的內容越來越豐富和複雜。目前沒有任何一個資料庫系統能夠支持SQL標準的所有概念和特性,同時不少軟體廠商對SQL基本命令集合進行了不同程度的修改和擴充,又可以支持標準外的一些功能特性。

3.1.2 SQL的特點

SQL的主要特點包括以下幾部分:

1.綜合統一

資料庫系統的主要功能是通過資料庫支持的數據語言來實現的。
非關係模型的數據語言一般分為:

  • 模式數據定義語言(模式DDL)
  • 外模式數據定義語言(外模式DDL)
  • 數據存儲有關的描述語言(DSDL)
  • 數據操縱語言(DML)

曾經的用戶資料庫投入運行後,如果需要修改模式,必須停止現有資料庫的運行,修改模式並且編譯後再重裝資料庫,十分麻煩。而SQL可以獨立完成資料庫生命周期中的全部活動。因此用戶在資料庫系統投入使用後還可以根據需要隨時的逐步的修改模式,並不影響資料庫運行,從而使得系統具有良好的可擴展性。

2.高度非過程化

非關係資料庫模型的數據操縱語言是面向過程的語言。而使用SQL的時候,只需要提出“做什麼”而無需知名怎麼做,因此無需瞭解存取路徑。這個工作由系統自動完成。

3.面向集合的操作方式

SQL採用幾何操作方式,對於CRUD的操作以及操作對象、查找結果等操作都可以對元組集合進行操作。

4.以統一語法結構提供多種使用方式

SQL既是獨立的語言,也是嵌入式語言。SQL可以嵌入到高級語言的程式中,而且無論是獨立使用還是嵌入使用,其語法結構是基本一致的嗎,因此統一了在不同語境下的語法使用。

3.1.3 SQL的基本概念

資料庫體系架構

用戶可以使用SQL對基本表和視圖進行基本操作,他們都是關係集合。
基本表是本身獨立存在的表,在關係資料庫管理系統中一個關係對應一個基本表。一個或者多個基本表對應一個存儲文件,一個表可以帶若幹索引,索引也可以存放在存儲文件中。視圖是一個或者幾個基本表導出的表,他不獨立存儲在資料庫中,也就是視圖是一個虛表,其中的信息是一個或者幾個基本表的映射,通常用於供人查看。存儲文件是數據的物理形式,存儲文件的邏輯結構組成了關係資料庫的內模式,其物理結構對最終用戶是隱蔽的。

3.2 資料庫實例

圍繞如下資料庫定義:
資料庫實例1
資料庫實例2
資料庫實例3

3.3 數據定義

關係資料庫系統支持三級模式結構,其模式、外模式和內模式中的基本對象有模式、表、視圖和索引等。
資料庫數據定義

一個關係資料庫管理系統的實例中可以建立多個資料庫,一個資料庫中可以建立多個模式,一個模式下包含多個表、視圖和索引等資料庫對象。下文中的語句<>括弧中的為輸入內容,[]括弧內的是可選內容

3.3.1 模式的定義和刪除

模式定義語句如下:

CREATE SCHEMA <SCHEMA NAME> AUTHORIZATION <USER NAME> [<TABLE DEFINE>|<VIEW DEFINE>]

創建模式需要擁有資料庫管理員許可權,或者獲得了資料庫管理員授予的CREATE SCHEMA許可權。在創建模式的時候也可以執行創建基本表、視圖等語句。定義模式實際上定義了一個命名空間,在這個空間中可以進一步定義該模式包含的資料庫對象,比如基本表、視圖、索引等。從語句可以看出,定義模式的同時需要將該模式的管理許可權授權給某用戶。

刪除模式語句如下:

DROP SCHEMA <SCHEMA NAME\88888>
<CASCADE|RESTRICT>

其中CASCADE和RESTRICT兩者必選其一,CASCADE(級聯)表示刪除該模式的同時將模式中所有資料庫對象都刪除,RESTRICT(限制)指的是如果模式中定義了下屬的資料庫對象,則拒絕執行刪除語句,除非該模式沒有下屬的對象。

3.3.1 模式的定義和刪除

模式定義語句如下:

CREATE SCHEMA <SCHEMA NAME> AUTHORIZATION <USER NAME> [<TABLE DEFINE>|<VIEW DEFINE>]

創建模式需要擁有資料庫管理員許可權,或者獲得了資料庫管理員授予的CREATE SCHEMA許可權。在創建模式的時候也可以執行創建基本表、視圖等語句。定義模式實際上定義了一個命名空間,在這個空間中可以進一步定義該模式包含的資料庫對象,比如基本表、視圖、索引等。從語句可以看出,定義模式的同時需要將該模式的管理許可權授權給某用戶。

刪除模式語句如下:

DROP SCHEMA <SCHEMA NAME\88888>
<CASCADE|RESTRICT>

其中CASCADE和RESTRICT兩者必選其一,CASCADE(級聯)表示刪除該模式的同時將模式中所有資料庫對象都刪除,RESTRICT(限制)指的是如果模式中定義了下屬的資料庫對象,則拒絕執行刪除語句,除非該模式沒有下屬的對象。

3.3.2 基本表的定義、刪除和修改

1. 常見數據類型

資料庫數據類型1
資料庫數據類型2

2.定義基本表

定義基本表的格式如下:

CREATE TABLE <TABLE NAME> (  
    <列名><數據類型>[列完整性約束條件],  
    [<列名><數據類型>[列完整性約束條件],…]  
    [表完整性約束條件]  
)

其中主要的列完整性約束條件有:

  • PRIMARY KEY 主鍵
  • FOREIGN KEY (外碼名) REFERENCES 被參照表(被參照列) 外鍵
  • NOT NULL 非空
  • UNIQUE 唯一值

3.修改基本表

ALTER TABLE <TABLE NAME>  
    [ADD [COLUME] <新列名><數據類型>[完整性約束]] -- 新增表項  
    [ADD <表級完整性約束>] -- 增加表約束  
    [DROP [COLUME] <列名> [CASCADE|RESTRICT]] -- 刪除表項  
    [DROP CONSTRAINT <完整性約束名> [RESTRICT|CASCADE]] -- 刪除表約束  
    [ALTER COLUME <列名><數據類型>] -- 修改列數據類型

其中ADD用於新增內容,DROP用於刪除內容。DROP COLUMN用於刪除列,如果指定了CASCADE則會在刪除列之前先刪除引用該列的其他對象,比如視圖;如果指定了RESTRICT,則如果對象被引用,則RDBMS會拒絕刪除該列。DROP CONSTRAINT 用於刪除指定的完整性約束條件。ALTER COLUMN子句用於修改原有列的定義。

4.刪除基本表

DROP TABLE <表名> [RESTRICT|CASCADE]

如果是RESTRICT,則刪除是有約束條件的,基本表不能被其他表的約束所引用(比如外鍵),不能有視圖,也不能有觸發器,不能有存儲過程或者函數。如果有則刪除失敗。如果選擇CASCADE,則該表刪除沒有限制條件,刪除基本表的同時相關的依賴一併刪除。

5.模式和表

一個模式包含了多個基本表,每一個基本表都屬於一個模式,當定義一個基本表的時候有三種方法定義它所屬的模式:
方法一:在表名中明顯給出模式名

CREATE TABLE “S-T”.Student(…) -- Student的模式是S-T

方法二:在創建模式語句中同時創建表

方法三,設置所屬模式,在創建表時不需要給出模式名

使用語句

SHOW search_path

可以顯示當前的搜索路徑

6.索引的建立和刪除

當表的數據量比較大的時候,查詢操作會比較耗時,因此建立索引可以加快查詢速度。資料庫索引類似於圖書的目錄,能夠快速定位到需要查詢的內容。資料庫索引會有多種類型,包括順序文件上的索引、B+樹索引、散列索引等等。索引雖然會加速查詢速度,但是需要占用一定記憶體空間,當基本表更新的時候,索引也要做出變更,因此需要一些維護開銷。一般來說,建立和刪除索引由索資料庫管理員或者表的屬主(owner)負責完成。關係資料庫管理系統在執行查詢時會自動選擇合適的索引,用戶不能顯式選擇索引。索引是關係資料庫內部實現技術,屬於內模式範疇。

常見索引形式

  • 順序文件索引是針對按照指定屬性值升序或者降序的存儲關係。
  • B+樹索引是將索引屬性組織成B+樹的形式,B+樹的葉節點為屬性值和相應的元組指針。B+樹具有動態平衡的優點
  • 散列索引是建立若幹個同,將索引屬性按照其散列函數映射到相應的桶中
  • 點陣圖索引是用位向量記錄索引屬性中可能出現的值,每一個位向量對應一個可能值。

建立索引

在SQL語句中,建立索引語句如下:

CREATE [UNIQUE] [CLUSTER] INDEX 索引名  
ON <表名>(<列名>[<次序>] [, <列名>[<次序>]])

表名是基本表名字,

索引可與建立在該表的一列或者多列上,各列之間用逗號分隔,次序欄位可選ASC(升序)和DESC(降序)
UNIQUE指該索引每一個索引值對應唯一的數據記錄;CLUSTER指建立聚簇索引,聚簇索引會在後面介紹到

修改和刪除

ALTER INDEX <舊索引名> RENAME TO <新索引名>  
DROP INDEX <索引名>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • WPF應用中,控制項本身也可以通過實現事件代碼實現拖動的處理,不過如果我們使用GongSolutions.WPF.DragDrop來處理,事情會變得更加簡單輕鬆,它支持很多控制項的拖動處理,如ListBox, ListView, TreeView, DataGrid等源自ItemsControl的控制項,... ...
  • 一、條件 1、windows server主機一臺,我是windows server 2019(當然windows10或者10月份5日更新的windows11也是可以行的)。 2、SQL Sever,我用的是SQL Server2019。 3、Power BI Report Server預設位置安裝 ...
  • Parallel.ForEach Parallel.ForEach 是一個用於在集合上並行執行迭代操作的強大工具。它通過有效地利用多核處理器的能力來提高性能。Parallel.ForEach 不僅能夠簡化並行編程,而且它在執行簡單迴圈時可以提供比傳統迭代更好的性能。 下麵是一個簡單的示例,演示瞭如何 ...
  • 版本 Linux 6.5 背景 在學習cgroupv2的時候,想給子cgroup開啟cpu控制器結果失敗了: # 查看可以開啟哪些控制器 root@ubuntu-vm:/sys/fs/cgroup# cat cgroup.controllers cpuset cpu io memory hugetl ...
  • 使用 ssh-keygen 生成密鑰 參考資料 https://learn.microsoft.com/zh-cn/azure/virtual-machines/linux/create-ssh-keys-detailed 快速開始 以下 ssh-keygen 命令預設在 ~/.ssh 目錄中生成 ...
  • 家中有閑置的小新,是A卡正好合適裝linux 安裝前 關閉安全引導 通過關機鍵旁邊的重置口重新開機 OR 在開機界面按F2(開啟Hotkey 模式的要按Fn+F2) 進入BIOS 設置界面,關閉Secure Boot,這樣方便安裝linux 系統刻錄 linux有很多發行版 大家可以自行選擇,推薦U ...
  • ssh介紹 SSH,全稱為Secure Shell,是一種用於在網路中安全地進行遠程登錄和執行命令的協議。它通過加密的方式提供了對網路通信的保護,使得用戶可以在不安全的網路環境下安全地進行遠程管理和數據傳輸。 以下是 SSH 協議的一些重要特點和功能: 安全性:SSH 使用加密技術來保護數據在網路中 ...
  • 資料庫完整性包括正確性和相容性,DBMS通過提供約束條件機制、檢查方法和違約處理功能維護資料庫完整性,其中實體完整性通過主鍵確保唯一標識,參照實體性通過外鍵關聯,用戶定義完整性滿足特定應用需求,而觸發器和斷言提供事件驅動和複雜約束支持,共同構成資料庫保持一致性的關鍵機制。 ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...