Chap 10 SQL定義、操作與控制指令.

Slides:



Advertisements
Similar presentations
第二章 简单的 SQL 语句. 本章要点  创建一个简单的表  SQL 语句介绍  最简单的查询语句 select  带有限制条件的查询  查询结果的排序显示.
Advertisements

2010 年 6 月课件制作人:王亚楠 1 模块 2 项目开发概论 教学课件 年 6 月课件制作人:王亚楠 2 目录 目标 了解:数据库技术的基本概念与结构 理解:数据模型的分类与结构组成 掌握:关系数据库及 SQL 的基本理论 知识 掌握:数据库设计的方法与步骤 内容 2.1 数据库技术基础.
2011/11,12 南台資管 吳昭儀. 1. 使用者介面 (User Interface)  使用者操作畫面的安排  Textbox, ComboBox, ListBox, CheckList, … 2. 流程控制 (Process Control)  使用者輸入資料檢查  計算  資料輸出.
Java 技术与应用 数据库应用 ( 第 14 章 ) 西安交大 卫颜俊 2008 年 12 月 电子信箱: QQ: 网站 : /java.
第 7 章 数据库 1. Overview  数据库概述  数据库管理系统  数据库的体系结构和数据库模型  SQL 语言  数据库技术  构建数据库系统 2.
SQL 入门 SQL:Structured query language 北京传智播客教育.
第八单元 数据库MySQL应用基础 MySQL数据库应用基础 MySQ数据库操作使用 Mysql管理工具 第25章 数据库的增加/删除操作
第5章 关系数据库标准语言SQL 主讲:张丽芳.
十一 ASP对数据库的访问.
第2章 SQL语言初步 2.1 SQL的基本概念 2.2 基本表、索引的创建、删除和修改操作 2.3 SQL的查询语句——SELECT
第2讲 Transact-SQL语言.
第5章 索引及视图操作 数据库原理应用与实践 SQL SERver2014(第2版) 主编 贾铁军 科学出版社 编著 陈国秦 万程 邢一鸣
Chap 11 SQL基本查詢指令.
第3章 SQL语言初步 2017/3/14.
数据库原理及应用 《数据库原理及应用》课程组 荆楚理工学院.
第14章 預存程序 14-1 預存程序的基礎 14-2 建立與執行預存程序 14-3 預存程序的參數傳遞 14-4 預存程序的傳回值
第4章 关系数据库标准语言SQL 4.1 SQL语言概述 4.2 SQL数据查询功能 4.3 SQL数据操作功能 4.4 SQL数据定义功能.
資料庫 (Database) SQL Server 2008實作
第3章 SQL的基础知识 数据库管理及应用 3.1 SQL简介 3.2 SQL的数据模型 3.3 标识符 3.4 使用SQL语句管理数据库
数据库概述 简而言之,数据库(DataBase)就是一个存储数据的仓库。为了方便数据的存储和管理,它将数据按照特定的规律存储在磁盘上。通过数据库管理系统,可以有效的组织和管理存储在数据库中的数据。如今,已经存在了Oracle、SQL Server、MySQL等诸多优秀的数据库。在这一章中将讲解的内容包括。
数据库原理及设计 --作业.
第4讲 MySQL服务器的配置与应用.
Chap 13 視界與資料庫程式設計.
创建数据库 MySql创建数据库的语法: CREATE DATABASE 数据库名; 例: CREATE DATABASE mydb;
第三章 管理信息系统的技术基础 主要内容: 数据处理 数据组织 数据库技术 4. 计算机网络.
计算机应用基础 上海大学计算中心.
数据库原理 Database Principles 第五章 数据库完整性 Database Principles.
第2章 数据定义功能 创建表 在关系型数据模型中,表(Table)是最基本的数据结构。
第7章 建立資料表與完整性限制條件 7-1 資料型別 7-2 資料表的建立 7-3 建立完整性限制條件 7-4 修改與刪除資料表
關聯式資料庫.
第六章 學習SQL語言.
第 8 章 資料的 新增、修改與刪除.
資料庫系統 Database Systems
課程名稱:資料庫系統 授課老師:李春雄 博士
第4章 SQL语言基础及数据库定义 4.1 基本概念 4.2 SQL Server 提供的主要数据类型 4.3 数据定义.
二.資料庫系統建立與管理 Access 資料庫:windows下的單機資料庫 Access 操作 Mysql資料庫介紹.
2、掌握SQL中各种查询方法和数据更新方法 3、掌握SQL中视图的定义方法和用法 4、掌握SQL的授权机制
題庫解析:MTA資料庫檢定 授課老師:李春雄 博士
第 7 章 建立資料表與 資料庫圖表.
資料庫安全 (Database Security)
教 师:曾晓东 电 话: 数据库技术 教 师:曾晓东 电 话:
SQL語法 定義與操作指令.
Transact-SQL 語言設計教學.
第4章 關聯式資料庫模型 4-1 關聯式資料庫模型的基礎 4-2 關聯式資料庫模型的資料結構 4-3 關聯式資料庫模型的完整性限制條件
第7章 ADO.NET操作SQL Server数据库
建立/修改/刪除資料表 建立資料表 使用Enterprise Manager工具
MySQL数据库基础与实例教程 之 MySQL表结构的管理 郭水泉.
第五章 認識 SQL語言與 資料型別.
SQL SERVER 一些经典语句 1.
第四讲 数据库对象(视图、序列、同义词、索引)
第十七章 資料庫SQL 17-1 SELECT 17-2 INSERT 17-3 UPDATE 17-4 DELETE.
Ch4.SQL Server 2005資料庫組成員元件介紹
实验二讲评 … 张榆….
数据库技术.
第20章 MySQL数据库.
数据库技术与应用.
MySQL开发规范 DB组-张浩.
第6章 資料庫設計與實體關聯模型 6-1 資料庫設計的基礎 6-2 實體關聯模型 6-3 建立實體關聯圖 6-4 實體關聯圖的常見錯誤
第18章 SQL結構化查詢語言 18-1 SQL語言的基礎 18-2 SQL的查詢指令 18-3 SQL子查詢與合併查詢.
4.2 视图 (1) 视图是一个虚拟表,其内容来自对表查询的基础上。
CS, ZJU 4/18/2019 Chapter 7 数据库.
3.2 Mysql 命令行 1 查看数据库 SHOW DATABASES; 2 创建一个数据库test1 CREATE DATABASE test1; 3 选择你所创建的数据库 USE test1; (按回车键出现Database changed 时说明操作成功!) 4 查看现在的数据库中存在什么表.
6 SQL語言與資料庫建置 6-1 SQL語言的基礎 6-2 SQL Server的資料庫結構 6-3 建立使用者資料庫
3. SQL语言的应用 3.1 SQL历史和优点 3.2 数据查询 3.3 数据操纵.
SQL查询语句 蔡海洋.
第三章 SQL Server数据管理.
第 7 章 建立資料表與資料庫圖表.
第4章 表的创建与维护 4.1 数据类型 4.2 数据完整性约束 4.3 创建数据表 4.4 修改数据表 4.5 删除数据表.
11 檢視表的建立 11-1 檢視表的基礎 11-2 建立檢視表 11-3 修改與刪除檢視表 11-4 編輯檢視表的內容.
第4章 数据查询.
Presentation transcript:

Chap 10 SQL定義、操作與控制指令

10-1-1 SQL結構化查詢語言 「SQL」(Structured Query Language)的全名是結構化查詢語言,筆者簡稱為SQL語言,SQL語言是「ANSI」(American National Standards Institute)制定的標準資料庫語言,其版本分為: 1989年的ANSI-SQL 89 1992年制定的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 Language):資料庫安全管理的權限設定指令。

10-1-2 關聯式資料庫管理系統的查詢最佳化 SQL指令需要轉換成低階機器語言指令來執行查詢,其轉換的步驟即查詢處理模組(Query Processor)子系統的執行順序:

10-1-2 關聯式資料庫管理系統的查詢最佳化 SQL查詢的步驟 第二步:在查詢最佳化模組將它轉換成中間格式關聯式代數建立的「查詢樹」(Query Tree),然後執行最佳化處理產生「執行計劃」。 第三步:使用RDBMS提供的選擇、合併、投影等關聯代數運算子的演算法,從執行計劃產生所需的程式碼。 第四步:使用直譯或編譯方式將程式碼轉換成機器語言後,就可以執行SQL指令產生查詢結果。

10-1-2 關聯式資料庫管理系統的查詢最佳化 查詢樹(Query Tree)是一棵關聯式代數運算式的樹狀結構,查詢樹的節點規則,如下所示: 關聯表是樹的葉節點(Leaf Nodes)。 關聯式代數運算子是中間節點(Internal Nodes)。

查詢最佳化-查詢樹圖例 SELECT Students.name, Classes.room FROM Students, Classes WHERE Students.sid = Classes.sid and Students.GPA >= 3.0 and Classes.c_no = ‘CS222’

查詢最佳化模組 查詢最佳化模組(Query Optimizer)的功能是在最佳化查詢樹,讓查詢樹執行的更有效率。 最佳化的作法有很多種,最簡單的方式是將查詢樹的節點轉換成更有效率且相等功能的節點,這些最佳化規則稱為啟發式查詢最佳化(Heuristic Query Optimization)技術。

查詢最佳化技術 啟發式查詢最佳化(Heuristic Query Optimization):這是規則基礎的最佳化,使用關聯式代數已知的轉換規則產生最有效率的執行計劃,例如:將卡笛生乘積運算和之後的選擇運算以合併運算來取代。 造句法式查詢最佳化(Syntactical Query Optimization):以查詢樹自行造句找出所有同等功能的可能關聯式代數運算式,其最佳化的依據主要在評估是否有索引可以改進執行效率,以便找出最佳的執行計劃。

查詢最佳化技術 成本基礎式查詢最佳化(Cost-Based Query Optimization):使用RDBMS各種資訊評估使用那一種順序執行關聯式代數運算式擁有最低的成本,以找出最有效率的存取方式,這是SQL Server和目前大多數RDBMS採用的最佳化技術。 語意式查詢最佳化(Semantic Query Optimization):語意式查詢最佳化需要查詢最佳化模組了解資料庫綱要,可以自行依所知的系統限制來簡化或刪除查詢結果是空集合的部分查詢,而且可以自行評估是否使用索引來加速資料存取。

10-1-2 關聯式資料庫管理系統的查詢最佳化 執行計劃(Execution Plan)是從已經最佳化的查詢樹轉換而得的一個執行策略。執行計劃包含如何存取每一個關聯表的資料存取方式。 例如:關聯表使用那一個屬性排序,或是否存在其他屬性的索引。

執行計劃演算法 選擇運算:使用線性搜尋(Linear Search)、二元搜尋(Binary Search)或雜湊表搜尋法(Hash Table Search)來找尋值組,在索引部分可以使用叢集索引(Clustering Index)或B-樹演算法。 合併運算:使用巢狀迴圈合併(Nested-loop Join)、單迴圈合併(Single-loop Join)、排序合併(Sort Merge Join)和雜湊合併(Hashing Merge Join)等多種合併演算法。 投影運算:沒有特別的演算法,因為只是刪除一些關聯表的屬性。

Instructors與Courses資料表

Classes資料表 Classes資料表

10-4 資料定義語言 SQL的資料定義語言(DDL)是用來建立關聯式資料庫綱要,也就是在資料庫建立每一個關聯表綱要、視界、索引和設定完整性限制條件。 DDL指令可以分成數種,如下所示: 建立資料表指令:SQL指令建立基底關聯表是使用CREATE TABLE指令,同時還可以設定關聯表的完整性限制條件。 建立視界指令:建立視界(Views)的指令是CREATE VIEW。 建立索引指令:建立資料表索引的DDL指令,也是在本節說明。

10-4-1 CREATE TABLE 語法 CREATE TABLE table_name ( column1 datatype [ 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-語法說明 NOT NULL | NULL:欄位值是否可以為虛值,如果沒有指明,預設是NULL,可以是空值。 DEFAULT:指定欄位的預設值,如果欄位沒有輸入資料,預設是填入之後的value1~N值。 PRIMARY KEY ():指定資料表的主鍵,括號內是主鍵的欄位,如果是複合鍵,欄位請使用逗號分隔。 FOREIGN KEY ()/REFERENCES ():指定資料表的外來鍵,括號為外來鍵的欄位清單,REFERENCE是參考的資料表,括號是參考資料表的主鍵。 CHECK ():設定欄位的限制條件,在括號內是條件的運算式。

10-4-1 CREATE TABLE新增關聯表 建立Students資料表: 在School資料庫建立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資料表: 在School資料庫建立Instructors資料表的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資料表: 在School資料庫建立Courses資料表的SQL指令,主鍵是c_no欄位,如下所示: CREATE TABLE Courses ( c_no CHAR(5) NOT NULL , title VARCHAR(30) NOT NULL , credits INT DEFAULT 3, PRIMARY KEY (c_no) )

10-4-1 CREATE TABLE新增關聯表 建立Classes資料表: 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 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 table_name ADD column_name datatype DROP COLUMN column_name

10-4-2 ALTER TABLE更改關聯表綱要 新增資料表欄位範例 在Students資料表新增SSN欄位的身份證字號,資料型態是CHAR(10) ,其SQL指令: ALTER TABLE Students ADD SSN CHAR(10) 刪除資料表欄位範例 在Students資料表刪除欄位SSN,SQL指令: DROP COLUMN SSN

10-4-2 ALTER TABLE更改關聯表綱要 新增/刪除資料表的主鍵 ALTER TABLE table_name ADD PRIMARY KEY (column_list) DROP PRIMARY KEY

10-4-2 ALTER TABLE更改關聯表綱要 新增主鍵範例 使用ALTER TABLE指令新增Employees的主鍵SSN,其SQL指令如下所示: ALTER TABLE Employees ADD PRIMARY KEY (SSN)

10-4-2 ALTER TABLE更改關聯表綱要 新增/刪除資料表的外來鍵 ALTER TABLE table_name ADD CONSTRAINT constraint_name FOREIGN KEY (column_list) REFERENCES table_name (column_list) DROP CONSTRAINT constraint_name

10-4-2 ALTER TABLE更改關聯表綱要 新增外來鍵範例 以上一節的Employees資料表為例,使用ALTER TABLE指令新增Employees資料表的外來鍵eid欄位,它是參考到Instructors的eid欄位,其SQL指令如下所示: ALTER TABLE Employees ADD CONSTRAINT constraint_eid FOREIGN KEY (eid) REFERENCES Instructors (eid)

10-4-2 ALTER TABLE更改關聯表綱要 刪除外來鍵範例 在Employees資料表刪除外來鍵,也就是刪除名為constraint_eid的限制條件,其SQL指令如下所示: ALTER TABLE Employees DROP CONSTRAINT constraint_eid

10-4-2 ALTER TABLE更改關聯表綱要 新增/刪除欄位的限制條件 ALTER TABLE table_name ADD CONSTRAINT constraint_name DEFAULT value FOR column_name | CHECK (expr) DROP CONSTRAINT constraint_name

10-4-2 ALTER TABLE更改關聯表綱要 新增欄位預設值範例 在Employees資料表新增name欄位預設值,其SQL指令如下所示: ALTER TABLE Employees ADD CONSTRAINT default_name DEFAULT ‘陳會安’ FOR name

10-4-2 ALTER TABLE更改關聯表綱要 新增欄位的限制條件範例 在Students學生資料表新增生日birthday欄位限制條件,其SQL指令如下所示: ALTER TABLE Students ADD CONSTRAINT check_birthday CHECK (birthday >= '1950-1-1' and birthday <= '2000-12-31')

10-4-3 DROP TABLE刪除整個關聯表 對於資料庫已經存在的基底關聯表,可以使用DROP TABLE 指令刪除指定的資料表,刪除的範圍包含資料表索引、記錄和視界,其基本語法如下所示: DROP TABLE table_name 上述語法是從資料庫刪除table_name的資料表。 刪除Employees資料表的SQL指令: DROP TABLE Employees

10-4-4 TRUNCAT TABLE刪除關聯表內容 TRUNCATE TABLE table_name 刪除Classes資料表內容,其SQL指令如下所示: TRUNCATE TABLE Classes

10-4-5 CREATE INDEX建立索引 以單層有序索引(Single Level Ordered Index)來說,使用主鍵排序建立的索引稱為「主索引」(Primary Index)。非主鍵排序的索引稱為叢集索引(Clustering Index),其他非排序欄位稱為「次索引」(Secondary Index),也稱為非叢集索引(Non-clustering Index)。 一個基底關聯表只能擁有一個主索引或叢集索引來決定記錄的排序方式,如果還有其他索引一定是次索引,在一個基底關聯表可以擁有多個次索引。

10-4-5 CREATE INDEX建立索引 DDL的CREATE INDEX指令可以建立基底關聯表的索引,其基本語法如下所示: CREATE [ UNIQUE ] INDEX index_name ON table_name (column_name[(length)],... ) [ ASC|DESC ] 上述語法可以建立SQL Server資料表的非叢集索引,UNIQUE是指索引值為唯一,表示不能有2筆記錄擁有相同索引值,index_name是索引名稱,column_name欄位如果不只一個,請使用逗號分隔。length欄位是長度,可以使用部分欄位值來建立索引資料,ASC是由小到大排序,DESC是由大到小。

10-4-5 CREATE INDEX建立索 建立資料表的索引範例 在Students學生資料表新增欄位name索引資料,其SQL指令如下所示: CREATE INDEX index_students ON Students(name)

10-4-6 DROP INDEX刪除索引 DDL的DROP INDEX指令可以刪除基底關聯表的索引資料,其基本語法如下所示: DROP INDEX table_name.index_name 上述table_name是資料表名稱,index_name是索引名稱。 刪除資料表的索引: 在Students學生資料表刪除索引資料的SQL指令,如下所示: DROP INDEX Students.index_students

10-5 資料操作語言 SQL的資料操作語言(DML)可以新增、刪除和更新資料表的記錄,換句話說,DDL是建立資料庫綱要,DML是建立資料庫副本(Instance)。 SQL語言的資料表操作指令一共有3個,如下表所示: INSERT:在資料表插入一筆新記錄 UPDATE:更新資料表的記錄,這些記錄是已經存在的記錄 DELETE:刪除資料表的記錄

10-5-1 INSERT新增記錄-語法 SQL語言的INSERT指令可以新增一筆記錄到資料表,INSERT指令的基本語法,如下所示: INSERT INTO table (column1,column2,…..) VALUES ('value1', 'value2 ', …) 上述SQL指令的table為新增記錄的資料表名稱,column1~n是資料表內的欄位名稱,不需全部欄位,不過需要包含所有非虛值欄位,value1~n是對應的欄位值。

10-5-1 INSERT新增記錄-注意事項 INSERT指令的注意事項,如下所示: 不論是欄位或值的清單,都需要使用逗號分隔。 在INSERT指令VALUES的值中,數值不用單引號包圍,字元與日期/時間需要單引號括起。 INSERT指令的欄位名稱清單,並不需要和資料表定義的欄位數目或順序相同,只需列出需要值的欄位,不過括號內的欄位名稱順序要和VALUES值的順序相同。

10-5-1 INSERT新增記錄-範例 新增記錄: 在Students新增一筆學生記錄的SQL指令,如下所示: INSERT INTO Students VALUES ('S001','陳會安', '02-22222222','1967/09/03',3.7) 上述SQL指令可以新增一筆記錄。

10-5-2 UPDATE更新記錄-語法 SQL語言的UPDATE指令可以將資料表符合條件的記錄,更新指定欄位的內容: UPDATE table SET column1 = ‘value1’ WHERE conditions table是資料表,SET子句column1是資料表的欄位名稱,不用全部只需更新欄位,value1是更新欄位值。 更新的欄位不只一個時使用逗號分隔: UPDATE table SET column1 = 'value1' , column2 = 'value2' WHERE conditions

10-5-2 UPDATE更新記錄 UPDATE指令的注意事項,如下所示: 更新記錄: WHERE子句是UPDATE指令的必要元素,如果沒有此條件,資料表所有記錄欄位都會被更新。 更新欄位值如果為數值不用單引號包圍,字元與日期/時間需要使用單引號包圍。 更新記錄: 在資料表Students更改學號S001生日和GPA: UPDATE Students SET birthday='1968-09-12', GPA=3.0 WHERE sid = 'S001'

10-5-3 DELETE刪除記錄-語法 SQL語言的DELETE指令可以將資料表符合條件的記錄刪除掉,DELETE指令的基本語法,如下所示: DELETE FROM table WHERE conditions table是資料表,WHERE子句conditions為刪除記錄的條件,口語來說是:「將符合conditions條件的記錄刪除掉」。

10-5-3 DELETE刪除記錄 DELETE指令的注意事項,如下所示: 刪除記錄: 在資料表Students刪除學號S001記錄: WHERE子句是DELETE指令的必要元素,如果沒有此條件,資料表內的所有記錄都會被刪除掉。 WHERE條件可以使用=、<>、>、<=和>=等比較運算子。 WHERE條件如果不只一個條件,可以使用邏輯運算子and或or連結。 刪除記錄: 在資料表Students刪除學號S001記錄: DELETE FROM Students WHERE sid = 'S001'

10-6 資料控制語言-說明 SQL語言的資料控制語言(Data Control Language,DCL)可以定義資料庫安全管理所需的規則,授予或撤回使用者的相關權限,讓使用者: 只能執行授權的操作和處理擁有權限的資料。 限制無法執行或取得沒有授權的操作或資料。

10-6 資料控制語言-GRANT指令 GRANT指令可以授予資料庫使用者的權限,其基本語法如下所示: GRANT { ALL [ PRIVILEGES ] | privileges [ (column [ ,columnn]) ] [,privileges…] } ON table_name TO user_name [,user_name ...] 上述語法可以在ON子句指定授予哪一個table_name資料表的權限,在privileges權限的括號中可以指定擁有哪些欄位的權限。

10-6 資料控制語言-REVOKE指令 REVOKE指令是對應GRANT指令,可以徹回某位使用者所授予的權限,其基本語法如下所示: REVOKE { ALL [ PRIVILEGES ] | privileges [ (column [ ,columnn]) ] [,privileges…] } ON table_name FROM user_name [,user_name ...] 上述語法可以在ON子句指定徹回哪一個table_name資料表的權限,在privileges權限的括號中可以指定撤回哪些欄位的權限。