范例建立资料表的索引课件.ppt
《范例建立资料表的索引课件.ppt》由会员分享,可在线阅读,更多相关《范例建立资料表的索引课件.ppt(60页珍藏版)》请在三一办公上搜索。
1、第10章 SQL定義、操作與控制指令,10-1 SQL語言的基礎10-2 SQL查詢工具10-3 資料庫的實體資料模型10-4 資料定義語言10-5 資料操作語言10-6 資料控制語言10-7 產生SQL Server指令碼精靈,10-1 SQL語言的基礎,10-1-1 SQL結構化查詢語言10-1-2 關聯式資料庫管理系統的查詢最佳化,10-1-1 SQL結構化查詢語言-說明,SQL(Structured Query Language)的全名是結構化查詢語言,筆者簡稱為SQL語言,SQL語言是ANSI(American National Standards Institute)制定的標準資料
2、庫語言,其版本分為:1989年的ANSI-SQL 891992年制定的ANSI-SQL 92,也稱為SQL 2,這是目前關聯式資料庫的標準語言最新版ANSI-SQL 99稱為SQL 3,適用在物件關聯或導向式資料庫的SQL語言。,10-1-1 SQL結構化查詢語言-種類,SQL語言依指令功能,可以分成三類,如下所示:資料定義語言DDL(Data Definition Language):建立資料表、視界和索引等的SQL指令。資料操作語言DML(Data Manipulation Language):資料表記錄插入、刪除、更新和查詢指令。資料控制語言DCL(Data Control Langua
3、ge):資料庫安全管理的權限設定指令。,10-1-2 關聯式資料庫管理系統的查詢最佳化-執行順序圖例,SQL指令需要轉換成低階機器語言指令來執行查詢,其轉換的步驟即查詢處理模組(Query Processor)子系統的執行順序,如下圖所示:,10-1-2 關聯式資料庫管理系統的查詢最佳化-SQL查詢的步驟,第一步:在查詢剖析器檢查SQL語言的語法是否正確,且驗證屬性和關聯表名稱是否存在。第二步:在查詢最佳化模組將它轉換成中間格式關聯式代數建立的查詢樹(Query Tree),然後執行最佳化處理產生執行計劃(Execution Plan)。第三步:使用RDBMS提供的選擇、合併、投影等關聯代數運
4、算子的演算法,從執行計劃產生所需的程式碼。第四步:使用直譯或編譯方式將程式碼轉換成機器語言後,就可以執行SQL指令產生查詢結果。,10-1-2 關聯式資料庫管理系統的查詢最佳化-查詢樹(Query Tree),查詢樹(Query Tree)是一棵關聯式代數運算式的樹狀結構,查詢樹的節點規則,如下所示:關聯表是樹的葉節點(Leaf Nodes)。關聯式代數運算子是中間節點(Internal Nodes)。,10-1-2 關聯式資料庫管理系統的查詢最佳化-查詢樹圖例,SELECT Students.name,Classes.roomFROM Students,ClassesWHERE Studen
5、ts.sid=Classes.sid and Students.GPA=3.0 and Classes.c_no=CS222,10-1-2 關聯式資料庫管理系統的查詢最佳化-查詢最佳化模組,查詢最佳化模組(Query Optimizer)的功能是在最佳化查詢樹,讓查詢樹執行的更有效率。最佳化的作法有很多種,最簡單的方式是將查詢樹的節點轉換成更有效率且相等功能的節點,這些最佳化規則稱為啟發式查詢最佳化(Heuristic Query Optimization)技術。,10-1-2 關聯式資料庫管理系統的查詢最佳化-查詢最佳化技術1,啟發式查詢最佳化(Heuristic Query Optimiz
6、ation):這是規則基礎的最隹化,使用關聯式代數已知的轉換規則產生最有效率的執行計劃,例如:將卡笛生乘積運算和之後的選擇運算以合併運算來取代。造句法式查詢最佳化(Syntactical Query Optimization):以查詢樹自行造句找出所有同等功能的可能關聯式代數運算式,其最佳化的依據主要在評估是否有索引可以改進執行效率,以便找出最佳的執行計劃。,10-1-2 關聯式資料庫管理系統的查詢最佳化-查詢最佳化技術2,成本基礎式查詢最佳化(Cost-Based Query Optimization):使用RDBMS各種資訊評估使用那一種順序執行關聯式代數運算式擁有最低的成本,以找出最有效
7、率的存取方式,這是SQL Server和目前大多數RDBMS採用的最佳化技術。語意式查詢最佳化(Semantic Query Optimization):語意式查詢最佳化需要查詢最佳化模組了解資料庫綱要,可以自行依所知的系統限制來簡化或刪除查詢結果是空集合的部分查詢,而且可以自行評估是否使用索引來加速資料存取。,10-1-2 關聯式資料庫管理系統的查詢最佳化-執行計劃,執行計劃(Execution Plan)是從已經最佳化的查詢樹轉換而得的一個執行策略。執行計劃包含如何存取每一個關聯表的資料存取方式。例如:關聯表使用那一個屬性排序,或是否存在其他屬性的索引。,10-1-2 關聯式資料庫管理系統
8、的查詢最佳化-執行計劃演算法,選擇運算:使用線性搜尋(Linear Search)、二元搜尋(Binary Search)或雜湊表搜尋法(Hash Table Search)來找尋值組,在索引部分可以使用叢集索引(Clustering Index)或B-樹演算法。合併運算:使用巢狀迴圈合併(Nested-loop Join)、單迴圈合併(Single-loop Join)、排序合併(Sort Merge Join)和雜湊合併(Hashing Merge Join)等多種合併演算法。投影運算:沒有特別的演算法,因為只是刪除一些關聯表的屬性。,10-2 SQL查詢工具,10-2-1 Query E
9、xpress查詢工具10-2-2 使用Query Express查詢工具,10-2-1 Query Express查詢工具-說明,Query Express查詢工具是Joseph Albahari所開發的SQL查詢工具,它的操作介面類似舊版SQL Server 2000版的Query Analyzer。Query Express不只可以作為SQL Server或Oracle的客戶端工具,它還可以作為MSDE和SQL Server 2005 Express的查詢工具。Query Express支援.NET Framewrok 2.0版,它是使用C#和ADO.NET建立的客戶端資料庫應用程式,使用
10、OLE DB連接資料庫伺服器來執行SQL指令。,10-2-1 Query Express查詢工具-架構,主從架構的資料庫系統,客戶端工具Query Express使用微軟OLE DB來連接伺服端SQL Server、Oracle或與OLE DB相容的資料庫伺服器。,10-2-2 使用Query Express查詢工具-啟動Query Express,請將書附光碟QExpress.zip壓縮檔案解開後,按二下【QueryExpress.exe】程式檔案啟動Query Express,如下圖所示:,10-2-2 使用Query Express查詢工具-結束Query Express,結束Query
11、 Express請執行檔案結束指令,即可中斷連接、關閉查詢視窗和結束Query Express的執行。,10-2-2 使用Query Express查詢工具-開啟與執行SQL指令碼,當在編輯視窗輸入SQL指令後,只需按上方工具列的【儲存查詢】鈕,就可以儲存成副檔名為.sql的程式碼檔案。對於書附光碟眾多的SQL指令碼檔案,我們可以使用Query Express來載入和執行。,10-3 資料庫的實體資料模型-Students資料表,當完成第6章和第7章的School學校資料庫設計後,我們就可以依據資料庫設計來建立實體資料模型(Physical Data Model),然後在資料庫使用SQL指令新
12、增所需的資料表。Students資料表,10-3 資料庫的實體資料模型-Instructors與Courses資料表,Instructors資料表Courses資料表,10-3 資料庫的實體資料模型-Classes資料表,Classes資料表,10-4 資料定義語言,10-4-1 CREATE TABLE新增關聯表10-4-2 ALTER TABLE更改關聯表綱要10-4-3 DROP TABLE刪除整個關聯表10-4-4 TRUNCAT TABLE 刪除關聯表內容10-4-5 CREATE INDEX建立索引10-4-6 DROP INDEX刪除索引,10-4 資料定義語言,SQL的資料定義
13、語言(DDL)是用來建立關聯式資料庫綱要,也就是在資料庫建立每一個關聯表綱要、視界、索引和設定完整性限制條件。DDL指令可以分成數種,如下所示:建立資料表指令:SQL指令建立基底關聯表是使用CREATE TABLE指令,同時還可以設定關聯表的完整性限制條件,在這一節筆者主要說明的是DDL指令。建立視界指令:建立視界(Views)的指令是CREATE VIEW,詳細的說明請參閱第13章。建立索引指令:建立資料表索引的DDL指令,也是在本節說明。,10-4-1 CREATE TABLE新增關聯表-CREATE TABLE 語法,CREATE TABLE table_name(column1 dat
14、atype NOT NULL|NULL DEFAULT value1,column2 datatype NOT NULL|NULL DEFAULT value2,column3 datatype NOT NULL|NULL DEFAULT value3,.columnN datatype NOT NULL|NULL DEFAULT valueN,PRIMARY KEY(column_list),FOREIGN KEY(column_list)REFERENCES table_name(column_list),CHECK(expr),10-4-1 CREATE TABLE新增關聯表-語法說明,
15、NOT NULL|NULL:欄位值是否可以為虛值,如果沒有指明,預設是NULL,可以是空值。DEFAULT:指定欄位的預設值,如果欄位沒有輸入資料,預設是填入之後的value1N值。PRIMARY KEY():指定資料表的主鍵,括號內是主鍵的欄位,如果是複合鍵,欄位請使用逗號分隔。FOREIGN KEY()/REFERENCES():指定資料表的外來鍵,括號為外來鍵的欄位清單,REFERENCE是參考的資料表,括號是參考資料表的主鍵。CHECK():設定欄位的限制條件,在括號內是條件的運算式。,10-4-1 CREATE TABLE新增關聯表-建立Students資料表,建立Students資
16、料表:Ch10-4-1-1.sql在School資料庫建立Students資料表,SQL指令如下所示:CREATE TABLE Students(sid CHAR(4)NOT NULL,name VARCHAR(12)NOT NULL,tel VARCHAR(15),birthday DATETIME,GPA FLOAT,PRIMARY KEY(sid),CHECK(GPA=0.0 and GPA=4.0),10-4-1 CREATE TABLE新增關聯表-建立Instructors資料表,建立Instructors資料表:Ch10-4-1-2.sql在School資料庫建立Instructo
17、rs資料表的SQL指令,主鍵是eid欄位,如下所示:CREATE TABLE Instructors(eid CHAR(4)NOT NULL,name VARCHAR(12)NOT NULL,rank VARCHAR(10),department VARCHAR(5),PRIMARY KEY(eid),10-4-1 CREATE TABLE新增關聯表-建立Courses資料表,建立Courses資料表:Ch10-4-1-3.sql在School資料庫建立Courses資料表的SQL指令,主鍵是c_no欄位,如下所示:CREATE TABLE Courses(c_no CHAR(5)NOT NU
18、LL,title VARCHAR(30)NOT NULL,credits INT DEFAULT 3,PRIMARY KEY(c_no),10-4-1 CREATE TABLE新增關聯表-建立Classes資料表,建立Classes資料表:Ch10-4-1-4.sql在School資料庫建立Classes資料表的SQL指令,如下所示:CREATE TABLE Classes(eid CHAR(4)NOT NULL,sid CHAR(4)NOT NULL,c_no CHAR(5)NOT NULL,time DATETIME,room VARCHAR(8),score FLOAT,PRIMARY
19、KEY(eid,sid,c_no),FOREIGN KEY(eid)REFERENCES Instructors(eid),FOREIGN KEY(sid)REFERENCES Students(sid),FOREIGN KEY(c_no)REFERENCES Courses(c_no),10-4-2 ALTER TABLE更改關聯表綱要-新增/刪除欄位(語法),新增/刪除資料表欄位如果資料表的欄位需要增減,並不需要重新建立資料表,可以使用ALTER TABLE指令來新增/刪除欄位,其基本語法如下所示:ALTER TABLE table_name ADD column_name datatyp
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 范例 建立 资料 索引 课件
链接地址:https://www.31ppt.com/p-4084815.html