《數據庫原理》ppt.ppt
《《數據庫原理》ppt.ppt》由會員分享,可在線閱讀,更多相關《《數據庫原理》ppt.ppt(67頁珍藏版)》請在裝配圖網上搜索。
1 數據庫系統(tǒng)原理 主講人 彭一明教材 數據庫系統(tǒng)原理教程 王珊等 清華大學出版社 2 前言 1 學習該課程的目的2 學習內容3 學習方法與要求4 參考書 3 1 學習該課程的目的 數據庫技術是數據管理的最新技術 20世紀60年代中期 它的出現極大地促進了計算機應用向各行各業(yè)滲透 目前基于數據庫技術的計算機應用已成為計算機應用的主流 占60 電子政務與管理信息系統(tǒng) MIS 政府 企業(yè) 銀行 飯店 旅游 醫(yī)療 遠程教育 網絡應用 計費系統(tǒng) 目錄服務 人工智能系統(tǒng) 專家系統(tǒng) 地理信息系統(tǒng) 工程 科學統(tǒng)計以及圖形 圖象 CAD 多媒體等領域有廣泛的應用 其數據庫技術起著關鍵作用 數據庫系統(tǒng)原理是從事數據庫應用系統(tǒng)開發(fā) 維護和數據庫管理系統(tǒng)的建立及相關理論研究必備的基礎知識 4 2 學習內容 本課以關系數據庫為重點比較全面講解數據庫的基本概念和基本技術 第一章緒論概述數據管理的進展 數據模型 數據庫 數據庫系統(tǒng) 數據庫管理系統(tǒng) 數據庫工程的基本概念 第二章 第四章講解關系數據庫關系數據庫數據模型 數據語言 關系數據庫語言SQL 關系數據庫設計理論第五章數據庫保護安全性 完整性 并發(fā)控制 恢復第六章數據庫設計第七章關系數據庫管理系統(tǒng)產品實例第八章數據庫技術新進展 5 3 學習方法與要求 該課的特點 以學習數據庫的基本概念 基本技術和數據庫設計為主 不象學習sqlserver oracle 學習語言 編程為主 有些概念和語句的語法不僅要熟記 還要了解用在何處 作用是什么 怎么使用 認真看書 聽講 復習 思考 討論先修課有操作系統(tǒng) 離散數學 數據結構認真完成作業(yè)及每章同步練習題上機 通過MSSqlSerevr2000學習sql語言 6 兩次面授課程兩次語音答疑期末復習串講課程論壇 7 4 參考書 1 薩師煊 王珊 數據庫系統(tǒng)概論 第四版 高等教育出版社 2 徐潔磐 王銀銀 數據庫系統(tǒng)引論 1996南京大學出版社 3 王能斌 數據庫系統(tǒng) 1995電子工業(yè)出版社 4 李昭原主編 羅曉沛主審 數據庫技術新進展 1997清華大學出版社 5 余晨 李文炬編著 SQLServer2000培訓教程 2001年7月第1版2003年9月第7次印刷 清華大學出版社 6 上機內容 sql概要語法 隨課件光盤一起發(fā)布 8 第一章緒論 理解數據 數據庫 數據庫管理系統(tǒng)和數據庫系統(tǒng)的概念 掌握數據庫系統(tǒng)的特點 數據庫系統(tǒng)的三級模式結構 數據庫系統(tǒng)的組成 掌握數據模型的相關概念 熟練掌握E R模型的表示方法 9 1 數據 實際上是描述事物的符號記錄 2 數據管理是指對數據的分類 組織 編碼 儲存 檢索和維護 經歷了三個階段 1 人工管理階段 2 文件系統(tǒng)階段 3 數據庫系統(tǒng)階段3 數據庫 database 簡稱DB 數據庫是長期儲存在計算機內 有組織的 可共享的數據集合 4 數據庫管理系統(tǒng) 簡稱DBMS 是數據管理軟件 功能 數據庫在建立 運用和維護時由數據庫管理系統(tǒng)統(tǒng)一管理 統(tǒng)一控制 5 數據庫系統(tǒng) 簡稱DBS 指在計算機系統(tǒng)中引入數據庫后的系統(tǒng)構成 一般由數據庫 數據庫管理系統(tǒng) 及其開發(fā)工具 應用系統(tǒng) 數據庫管理員和用戶構成 10 數據庫系統(tǒng)特點 4頁 5點 1 數據的結構化 面向全組織復雜的數據結構 2 數據的共享性好 冗余度小 3 具有較高的數據與程序獨立性 4 數據由DBMS統(tǒng)一管理和控制 安全性控制 完整性控制 并發(fā)控制 數據庫恢復 5 數據的最小存取單位是數據項 7 數據的邏輯獨立性當數據的總體邏輯結構改變時 通過數據的總體邏輯結構與某類應用所涉及的局部邏輯結構之間的映象或轉換功能保持數據的局部邏輯結構不變 由于應用程序是依據數據的局部邏輯結構編寫的 所以應用程序不必修改 這就是數據與程序的邏輯獨立性 簡稱數據的邏輯獨立性 11 8 數據的物理獨立性當數據的存儲結構 或物理結構 改變時 通過數據的存儲結構與邏輯結構之間的映象或轉換功能保持數據的邏輯結構不變 從而應用程序也不必改變 這就是數據與程序的物理獨立性 簡稱數據的物理獨立性 9 數據模型的重要性及組成數據模型是數據庫系統(tǒng)的核心與基礎 各種機器上實現的DBMS軟件都基于某種數據模型 數據庫發(fā)展階段的劃分也是以數據模型的發(fā)展作為主要的依據和標志 10 數據模型由三部分組成 數據結構 數據操作 完整性約束 12 數據模型概述 在數據庫中用數據模型這個工具來抽象 表示和處理現實世界中的數據和信息 數據模型就是現實世界的模擬 數據模型應滿足三方面要求 一是能比較真實地模擬觀實世界 二是容易為人所理解 三是便于在計算機上實現 模型劃分為兩類 它們分屬于兩個不同的層次 第一類模型是概念模型 也稱信息模型 它是按用戶的觀點對數據和信息建模 另一類模型是數據模型 它是按計算機系統(tǒng)的觀點對數據建模 主要包括網狀模型 層次模型 關系模型等 13 數據模型是數據庫系統(tǒng)的核心和基礎 各種機器上實現的DBMS軟件都是基于某種數據模型的 為了把現實世界中的具體事物抽象 組織為某一DBMS支持的數據模型 通常分二步 首先把現實世界中的客觀對象抽象為某一種信息結構 這種信息結構并不依賴于具體的計算機系統(tǒng) 不是某個DBMS支持的數據模型 而是概念級的模型 概念模型 然后再把概念模型轉換為計算機上某一DBMS支持的數據模型 概念模型實際上是現實世界到機器世界的一個中間層次 用于信息世界的建模 是現實世界到信息世界的第一層抽象 是用戶與數據庫設計人員之間進行交流的語言 概念模型 14 圖1 10對象的抽象模型 15 1 信息世界的基本概念 信息世界 概念模型 涉及的概念主要有 1 實體 entity 客觀存在并可相互區(qū)別的事物稱為實體 實體可以是具體的人 事 物 也可以是抽象的概念或聯(lián)系 例如 一個職工 一個學生 一個部門 一門課 學生的一次選課 部門的一次訂貨 老師與系的工作關系 即某位老師在某系工作 等 2 屬性 attribute 實體所具有的某一特性稱為屬性 一個實體可以由若干個屬性來刻畫 例如 學生實體可以由學號 姓名 性別 出生年份 系 入學時間等屬性組成 94002268 張山 男 1976 計算機系 1994 這些屬性組合起來表征了一個學生 16 3 碼 key 唯一標識實體的屬性集稱為碼 例如 學號是學生實體的碼 4 域 domain 屬性的取值范圍稱為該屬性的域 例如 學號的域為8位整數 姓名的域為字符串集合 年齡的域為小于35的整數 性別的域為 男 女 5 實體型 entitytype 用實體名及其屬性名集合來抽象和刻畫同類實體 稱為實體型 例如 學生 學號 姓名 性別 出生年份 系 入學時間 就是一個實體型 6 實體集 entityset 同型實體的集合稱為實體集 例如 全體學生就是一個實體集 17 7 聯(lián)系 relationship 在現實世界中 事務內部以及事務之間是有聯(lián)系的 在信息世界中 這些聯(lián)系反映為實體內部的聯(lián)系和實體之間的聯(lián)系 實體內部的聯(lián)系通常是指組成實體的各屬性之間的聯(lián)系 兩個實體型之間的聯(lián)系可以分為三類 一對一聯(lián)系 1 1 如果對于實體集A中的每一個實體 實體集B中至多有一個實體與之聯(lián)系 反之亦然 稱實體集A與實體集B具有一對一聯(lián)系 記為1 1 例如 班級與班長 18 一對多聯(lián)系 1 n 如果對于實體集A中的每一個實體 實體集B中有n個實體 n 0 與之聯(lián)系 反之對于實體集B中的每一個實體 實體集A中至多只有一個實體與之聯(lián)系 稱實體集A與實體集B具有一對多聯(lián)系 記為1 n 例如 班級與學生 19 多對多聯(lián)系 m n 如果對于實體集A中的每一個實體 實體集B中有n個實體 n 0 與之聯(lián)系 反之對于實體集B中的每一個實體 實體集A中有m個實體 m 0 與之聯(lián)系 稱實體集A與實體集B具有多對多聯(lián)系 記為m n 例如 課程與學生 20 概念模型應該能夠方便 準確地表示出信息世界中的常用概念 表示方法很多 其中最為常用的是P P S Chen于1976年提出的實體 聯(lián)系方法 entity relationshipapproach 該方法用E R圖來描述現實世界的概念 E R圖提供了表示實體型 屬性和聯(lián)系的方法是 實體型 用矩形表示 矩形框內寫明實體名 屬性 用橢圓形表示 并用無向邊將其與相應的實體連接 聯(lián)系 用菱形表示 菱形框內寫明聯(lián)系名 并用無向邊分別與有關實體連接起來 同時在無向邊旁標上聯(lián)系的類型 1 1 1 n或m n 概念模型的表示方法 21 11 概念模型常用表示方法 實體 聯(lián)系法 E R圖描述 E R圖成分 實體 屬性 聯(lián)系 會畫E R圖 22 完整的E R圖有屬性實體的屬性表示 23 E R圖實例 選修與組成的屬性標在聯(lián)系中 24 25 數據模型 在機器世界中不同的數據模型具有不同的數據結構形式 目前最常用的數據模型有層次模型 hierarchicalmodel 網狀模型 networkmodel 關系模型 relationalmodel 面向對象的模型 其中層次模型和網狀模型統(tǒng)稱為非關系模型 非關系模型的數據庫系統(tǒng)在20世紀70年代與80年代初非常流行 關系模型的數據庫系統(tǒng)80年代初到現在非常流行 面向對象模型是在20世紀80年代以來 面向對象的方法和技術在計算機各個領域的應用發(fā)展起來的 26 關系模型是目前最重要的一種模型 美國IBM公司的研究員E F codd于1970年發(fā)表題為 大型共享系統(tǒng)的關系數據庫的關系模型 的論文 文中首次提出了數據庫系統(tǒng)的關系模型 20世紀80年代以來 計算機廠商新推出的數據庫管理系統(tǒng) DBMS 幾乎都支持關系模型 數據庫領域當前的研究工作都是以關系方法為基礎 1 關系數據模型的數據結構在用戶看來 一個關系模型的邏輯結構是一張二維表 它由行和列組成 例如 圖l 23中的學生人事記錄就是一個關系模型 它涉及下列概念 關系數據模型 27 12 關系模型中幾個主要術語關系 元組 屬性 域 分量 碼 關系模式 關系 定義2 3D1 D2 Dn的子集叫作在域D1 D2 Dn上的關系 用R D1 D2 Dn 表示 關系是笛卡爾積的子集 所以關系也是一個二維表 元組 表的每行為一個元組 屬性 對每列起一個名字 稱為屬性 表中的一列即為一個屬性 域 domain 屬性的取值范圍 分量 元組中的一個屬性值 碼 候選碼 若關系中的某一屬性組的值能唯一地標識一個元組 而其真子集不行 則稱該屬性組為候選碼 主碼 若一個關系有多個候選碼 則選定其中一個為主碼關系模式 對關系的描述 一般表示為 R U 關系名 屬性1 屬性2 屬性n 三元組表示法 R U F 28 29 關系模式 對關系的描述 一般表示為 關系名 屬性1 屬性2 屬性n 例如 學生 學號 姓名 性別 系別 年齡 籍貫 課程 課程號 課程名 學分 在關系模型中 實體以及實體間的聯(lián)系都是用關系來表示 例如學生與課程之間的多對多聯(lián)系 選修 在關系模型中可以表示如下 選修 學號 課程號 成績 30 關系數據模型的操縱主要包括查詢 插入 刪除和更新數據 這些操作必須滿足關系的完整性約束條件 關系的完整性約束條件包括三大類 實體完整性 參照完整性和用戶定義的完整性 其具體含義將在后面介紹 關系模型中的數據操作是集合操作 操作對象和操作結果都是關系 即若干元組的集合 而不像非關系模型中那樣是單記錄的操作方式 另一方面 關系模型把存取路徑向用戶隱蔽起來 用戶只要指出 干什么 或 找什么 不必詳細說明 怎么干 或 怎么找 從而大大地提高了數據的獨立性 提高了用戶的生產率 Select fromstudent 2 關系數據模型的操縱與完整性約束 31 13 集中式數據庫系統(tǒng)的三級模式結構及二級映象 數據庫系統(tǒng)的三級模式結構是指數據庫系統(tǒng)是由外模式 模式和內模式三級構成 兩級映象功能是 外模式 模式映象 模式 內模式映象 32 掌握關系模型 關系 關系模式 關系數據庫 關系數據庫系統(tǒng)和關系數據庫管理系統(tǒng)的概念 正確理解關系的碼 外碼理解關系的完整性內容及規(guī)則會用關系代數表示查詢 一 基本概念 1 關系模型 由關系數據結構 關系操作集合和完整性約束三部分組成 關系的數據結構關系模型的數據結構非常單一 是一張扁平的二維表 現實世界的實體以及實體間的各種聯(lián)系都用關系二維表表示 關系操作特點 采用集合操作方式 即操作的對象和結果都是集合 完整性約束實體完整性 參照完整性和用戶定義的完整性 第二章關系數據庫 33 2 關系模式 41頁 定義2 4 關系的描述稱為關系模式 形式化表示R U D DOM F R為關系名 U為組成關系的諸屬性名 D為屬性的域 DOM表示屬性向域的映象 F是屬性間的數據依賴關系 通常簡記為R U 或記為R A1 A2 An 3 關系數據庫關系數據庫的型與值 42頁 關系模式是型 關系是值 關系數據庫模式與關系數據庫通常統(tǒng)稱為關系數據庫4 關系數據庫系統(tǒng) 支持關系模型的數據庫系統(tǒng) 5 關系數據庫管理系統(tǒng)簡稱為關系系統(tǒng) 34 二 關系模型三類完整性 42 實體完整性 參照完整性 用戶定義完整性實體完整性規(guī)則 參照完整性規(guī)則 主 外碼概念及用途 候選碼 若關系中的某一屬性組的值能唯一地標識一個元組 而其真子集不行 則稱該屬性組為候選碼 candidatekey 主碼 若一個關系有多個候選碼 則選定其中一個為主碼 primarykey 主屬性 候選碼中的屬性稱主屬性 非主屬性 不包含在任何候選碼中的屬性稱為非碼屬性也稱為非主屬性 規(guī)則2 1實體完整性規(guī)則 若屬性A是基本關系R的主屬性 則屬性A不能取空值 35 外碼 定義2 5設F是基本關系R的一個或一組屬性 但不是關系R的碼 如果F與基本關系S的主碼Ks相對應 則稱F是基本關系R的外碼 foreignkey 并稱基本關系R為參照關系 referencingrelation 基本關系S為被參照關系 referencedrelation 或目標關系 targetrelatton 關系R和S不一定是不同的關系 規(guī)則2 2參照完整性規(guī)則 若屬性 或屬性組 F是基本關系R的外碼 它與基本關系S的主碼Ks相對應 基本關系R和S不一定是不同的關系 則對于R中每個元組在F上的值必須為 或者取空值 F的每個屬性值均為空值 或者等于S中某個元組的主碼值 36 選擇又稱為限制 restriction 它是在關系R中選擇滿足給定條件的諸元組 記作 其中F表示選擇條件 1 選擇 selection 三 關系操作1 關系模型的操作 8種 傳統(tǒng)的集合運算4種 并 交 差 廣義笛卡爾積 專門的關系運算4種 選擇 投影 連接 除 操作方式的特點 集合操作2 用關系代數表示關系運算選擇 投影 連接 除 37 關系R上的投影是從R中選擇出若干屬性列組成新的關系 A R t A t R 其中A為R中的屬性列 投影操作是從列的角度進行的運算 連接 join 它是從兩個關系的笛卡爾積中選取屬性間滿足一定條件的元組 記作 2 投影 projection 自然連接 兩個關系中進行比較的分量必須是相同的屬性組 取值相同 并且要在結果中把重復的屬性去掉 即若R和S具有相同的屬性組B 則自然連接可記作 38 例1查詢信息系 IS系 全體學生Sdept IS Student 或 5 IS Student 例2查詢學生關系student在學生姓名和所在系兩個屬性上的投影 Sname Sdept student 或 student 例3查詢至少選修了一門其直接先行課為6號課程的學生姓名 52頁 Sname Cpno 6 Course SC Student 關系代數例題 例4檢索信息系 IS系 學生的姓名 Sname Sdept IS Student SelectSnamefromstudentwhereSdept IS 39 1 SQL語言SQL的數據定義功能 SQL的數據操縱功能SQL的數據查詢功能 SQL的數據控制功能2 嵌入式SQL語句與主語言之間的通信 第三章關系數據庫標準語言 SQL 40 SQL語言支持關系數據庫三級模式結構 如圖3 1所示 其中外模式對應于視圖 view 和部分基本表 basetable 模式對應于基本表 內模式對應于存儲文件 SQL語言支持三級模式結構 41 基本表是本身獨立存在的表 在SQL中一個關系對應一個表 一些基本表對應一個存儲文件 一個表可以帶若干索引 索引存放在存儲文件中 存儲文件的邏輯結構組成了關系數據庫的內模式 存儲文件的物理文件結構是任意的 視圖是從基本表或其他視圖中導出的表 它本身不獨立存儲在數據庫中 數據庫中只存放視圖的定義而不存放視圖對應的數據 這些數據仍存放在導出視圖的基本表中 因此視圖是一個虛表 用戶可以用SQL語言對視圖和基本表進行查詢 在用戶眼中 視圖和基本表都是關系 而存儲文件對用戶是透明的 基本表 存儲文件與視圖 42 修改視圖和索引怎么辦 數據定義 43 CREATETABLE 表名 列名 數據類型 列級完整件約束條件 列名 數據類型 列級完整性約束條件 表級完整性約束條件 其中 表名 是基本表的名字 它由一個或多個屬性 列 組成 屬性要說明類型與長度 建表的同時還可定義與該表有關的完整性約束條件 如果完整性約束條件涉及到該表的多個屬性列 則必須定義在表級上 1 定義基本表SQL語言使用CREATETABLE語句定義基本表 其一般格式如下 44 例1建立一個 學生 表Student 它由學號sno 姓名Sname 性別Ssex 年齡Sage 所在系Sdept5個屬性組成 其中學號屬性不能為空 并且其值是唯一的 CREATETABLEStudent SnoCHAR 5 NOTNULLUNIQUE SnameCHAR 20 Ssexchar 2 Sageint SdeptCHAR 15 系統(tǒng)執(zhí)行上面的語句后 就在數據庫中建立一個新的空的 學生 表 并將有關 學生 表的定義及有關約束條件存放在數據字典中 45 2 刪除基本表 DROPTABLE 表名 例5刪除Student表DROPTABLEStudent 46 3 建立與刪除索引 通過索引可以大大加快表的查詢 在基本表上建立一個或多個索引 系統(tǒng)在存取數據時會自動選擇合適的索引作為存取路徑 用戶不必也不能選擇索引 1 建立索引建立索引使用CREATEINDEX語句 其一般格式為 CREATE UNIQUE CLUSTER INDEXON 其中 表名 指定要建索引的基本表的名字 索引可以建在該表的一列或多列上 各列名之間用逗號分隔 每個 列名 后面還可以用 次序 指定索引值的排列次序 包括ASC和DESC 47 例6為學生 課程數據庫中的Student Course SC3個表建立索引 其中Student表按學號升序建立唯一索引 course表按課程號升序建立唯一索引 sc表按學號升序和課程號降序建唯一索引 CREATEUNIQUEINDEXStusnoONStudent Sno CREATEUNIQUEINDEXCoucnoONCourse Cno CREATEUNIQUEINDEXSCnoONSC SnoASC CnoDESC 2 刪除索引刪除索引使用DROPINDEX語句 其一般格式為DROPINDEX 索引名 例7刪除Student表的Stusname索引 stusno DROPINDEXStusname DROPINDEXStusno 48 CREATEVIEW 視圖名 列名 列名 AS 子查詢 WITHCHECKOPTION 其中子查詢可以是任意復雜的SELECT語句 但通常不允許含有ORDERBY子句和DISTINCT短語 WITHCHECKOPTION表示對視圖進行UPDATE INSERT和DELETE操作時要保證更新 插入或刪除的行滿足視圖定義中的謂詞條件 即子查詢中的條件表達式 如果CREATEVIEW語句僅指定了視圖名 省略了組成視圖的各個屬性列名 則隱含該視圖由子查詢中SELECT子句目標列中的諸字段組成 4 建立與刪除視圖1 建立視圖 49 視圖建好后 若導出此視圖的基本表被刪除了 該視圖將失效 但一般不會被自動刪除 DROPVIEW 刪除視圖 50 數據操縱 51 SQL中數據更新包括插入數據 修改數據和刪除數據 3 4 1插入數據 SQL的數據插入語句INSERT通常有兩種形式 1 插入單個元組 52 例1將一個新學生記錄 學號 95020 姓名 陳冬 性別 男 所在系 IS 年齡 18歲 插入Student表中 例2插入一條選課記錄 95020 1 3 4 2修改數據 修改操作又稱為更新操作 其語句的一般格式為 新插入的記錄grade列上取空值 a b 53 其功能是修改指定表中滿足WHERE子句條件的元組 其中SET子句用于指定修改方法 即用 表達式 的值取代相應的屬性列值 如果省略WHERE子句 則表示要修改表中的所有元組 1 修改某一個元組的值例4將學生95001的年齡改為22歲 2 修改多個元組的值例5將所有學生的年齡增加1歲 UPDATE 表名 SET 列名 表達式 列名 表達式 WHERE 條件 54 DELETEFROM 表名 WHERE 條件 DELETE語句的功能是從指定表中刪除滿足WHERE子句條件的所有元組 如果省略WHERE子句 表示刪除表中全部元組 但表的定義仍在字典中 也就是說 DELETE語句刪除的是表中的數據 而不是關于表的定義 刪除某一個 或某些 元組的值例7刪除學號為95019的學生記錄 DELETEFROMStudentWHERESno 95019 3 4 3刪除數據 55 2 刪除多個元組的值 例8刪除所有學生的選課記錄 DELETEFROMSC 56 整個SELECT語句的含義是 根據WHERE子句的條件表達式 從FROM子句指定的基本表或視圖中找出滿足條件的元組 再按SELECT子句中的目標列表達式 選出元組中的屬性值形成結果表 如果有GROUP子句 則將結果按 列名1 的值進行分組統(tǒng)計 如果GROUP子句帶HAVING短語 則只有滿足指定條件的組才予輸出 如果有ORDER子句 則結果表還要按 列名2 的值的升序或降序排序 SELECT語句既可以完成簡單的單表查詢 也可以完成復雜的連接查詢和嵌套查詢 最基本的用法是 select列1 列2 列3 from表名 where條件 57 1 目標列表達式有以下可選格式 數據查詢 58 其中 屬性列名表達式 可以是由屬性列 作用于屬性列的聚集函數和常量的任意算術運算 十 一 組成的運算公式 集函數的一般格式為 59 WHERE子句的條件表達式有以下可選格式 60 數據查詢 61 2 連接查詢 自然連接 自身連接 例34查詢每一門課的間接先修課 外連接 例33 Student表為主體列出每個學生的基本情況及其選課情況 SELECTStudent Sno Sname Ssex Sage Sdept Cno GradeFROMStudentLEFTOUTERJOINSCONStudent Sno SC Sno 62 3 嵌套查詢 where語句中可包含另個查詢塊 嵌套查詢分為不相關子查詢 in 比較運算符 any all謂詞 和相關子查詢 exists 兩類 不相關子查詢是指子查詢的查詢條件不依賴于父查詢 它的求解方法是由里向外處理 相關子查詢是指子查詢的查詢條件依賴于外層父查詢的某個屬性值 它的求解方法是由外向里處理 IN ANY ALL 構造的子查詢 Where數據項IN 子查詢 子查詢輸出中有相應數據項相關子查詢 Whereexists 子查詢 子查詢的where條件中依賴于外層父查詢的某個屬性值用IN構造的相關子查詢 Where數據項IN 子查詢 子查詢輸出中有相應數據項且條件中依賴于外層父查詢的某個屬性值 63 選修了2號課程的學生姓名 解一 解二 解三 64 4 使用集函數 GROUPBY子句可以將查詢結果表的各行按一列或多列取值相等的原則進行分組 與集函數一起使用 即每一組都有一個函數值 例30查詢各個課程號與相應的選課人數 SELECTCno COUNT Sno FROMSCGROUPBYCno 查詢平均分 80分的課程號 SelectcnofromscgroupbycnoHavingavg grade 80 5 對查詢結果分組 SELECTCOUNT FROMStudent 65 6 匹配符檢索 7 空值檢索 謂詞ISNULL和ISNOTNULL可用來查詢空值和非空值 SELECTSno CnoFROMSCWHEREGradeISNUIL 8 對查詢結果排序 ORDERBY子句指定按照一個或多個屬性列的為升序 ASC 或降序 DESC 重新排列查詢結果 其中升序ASC為缺省值 SELECT FROMStudentORDERBYSdept SageDESC 66 六 數據控制語言 GRANT語句的一般格式為 GRANT 權限 權限 ON 對象類型 對象名 TO 用戶 用戶 WITHGRANTOPTION REVOKE 權限 權限 ON 對象類型 對象名 FROM 用戶 用戶 67 2嵌入式SQL語句與主語言之間的通信數據庫工作單元與源程序工作單元之間通信主要包括 向主語言傳遞SQL語句的執(zhí)行狀態(tài)信息 使主語言能夠據此控制程序流程 通過SQL通訊區(qū) SQLCA 解決 主語言向SQL語句提供參數 通過主變量解決 將SQL語句查詢數據庫的結果交主語言進一步處理 通過主變量和游標 CURSOR 實現 數據控制- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設計者僅對作品中獨創(chuàng)性部分享有著作權。
- 關 鍵 詞:
- 數據庫原理 數據庫 原理 ppt
裝配圖網所有資源均是用戶自行上傳分享,僅供網友學習交流,未經上傳用戶書面授權,請勿作他用。
鏈接地址:http://www.3dchina-expo.com/p-6577189.html