第02章 關(guān)系數(shù)據(jù)庫系統(tǒng)_第1頁
第02章 關(guān)系數(shù)據(jù)庫系統(tǒng)_第2頁
第02章 關(guān)系數(shù)據(jù)庫系統(tǒng)_第3頁
第02章 關(guān)系數(shù)據(jù)庫系統(tǒng)_第4頁
第02章 關(guān)系數(shù)據(jù)庫系統(tǒng)_第5頁
已閱讀5頁,還剩50頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、第2章關(guān)系數(shù)據(jù)庫基礎(chǔ),2,2.1關(guān)系數(shù)據(jù)庫系統(tǒng)概述,關(guān)系數(shù)據(jù)庫的發(fā)展SQLServer簡介關(guān)系數(shù)據(jù)庫標(biāo)準(zhǔn)語言SQL簡介SQLServer的Transact-SQL介紹關(guān)系數(shù)據(jù)庫的三層模式結(jié)構(gòu)SQLServer的數(shù)據(jù)庫存儲(chǔ)結(jié)構(gòu)建立數(shù)據(jù)庫SQLServer的安全管理簡介SQL標(biāo)準(zhǔn)中的架構(gòu),3,關(guān)系數(shù)據(jù)庫的發(fā)展,CODASYL于1962年發(fā)表的“信息代數(shù)”一文E.F.Codd從1970年起發(fā)表了一系列的論文20世紀(jì)70年代末的實(shí)驗(yàn)系統(tǒng)SystemR和Ingres從20世紀(jì)80年代逐步走向成熟,4,SQLServer簡介,20世紀(jì)80年代:誕生。1995年:SQLServer6.01996年:SQLS

2、erver6.51998年:SQLServer7.02000年:SQLServer20002005年:SQLServer20052008年:SQLServer20082012年:SQLServer2012,5,DBMS和解決方案,現(xiàn)在的SQLServer是關(guān)系數(shù)據(jù)庫管理系統(tǒng),但更是基于數(shù)據(jù)庫的全面應(yīng)用解決方案??梢詾閿?shù)據(jù)庫提供更安全可靠的存儲(chǔ)功能可以構(gòu)建和管理用于業(yè)務(wù)的高可用和高性能的數(shù)據(jù)應(yīng)用系統(tǒng)提供了分布式數(shù)據(jù)庫解決方案、商業(yè)智能和數(shù)據(jù)倉庫解決方案、數(shù)據(jù)集成服務(wù)解決方案、以及超越關(guān)系數(shù)據(jù)庫的應(yīng)用解決方案(如XML數(shù)據(jù)管理、空間數(shù)據(jù)管理)等。,6,版本,有多個(gè)版本,可以適合不同規(guī)模和場合的應(yīng)用

3、企業(yè)版標(biāo)準(zhǔn)版工作組版Web版開發(fā)者版學(xué)習(xí)版移動(dòng)版,7,關(guān)系數(shù)據(jù)庫標(biāo)準(zhǔn)語言SQL簡介,SQL的歷史(書P34)SQL的特點(diǎn)SQL是一種一體化的語言,它包括了數(shù)據(jù)定義、數(shù)據(jù)查詢、數(shù)據(jù)操縱和數(shù)據(jù)控制等方面的功能,它可以完成數(shù)據(jù)庫活動(dòng)中的全部工作。SQL語言是一種高度非過程化的語言。SQL語言非常簡潔。SQL語言可以直接以命令方式交互使用,也可以嵌入到程序設(shè)計(jì)語言中以程序方式使用。,8,SQLServer的Transact-SQL介紹,SQLServer使用的語言稱作Transact-SQL,簡稱T-SQL,它不僅包括SQL操作的內(nèi)容,還有一般程序設(shè)計(jì)的能力。數(shù)據(jù)類型與變量說明運(yùn)算符與表達(dá)式函數(shù)全局變

4、量程序語句,9,SQLServer2005/2008支持的數(shù)據(jù)類型,10,1.數(shù)據(jù)類型與變量說明,在T-SQL中用DECLARE語句說明內(nèi)存變量,用SELECT語句或SET語句賦值。變量說明的命令格式為:DECLARE,.例:聲明一個(gè)長度為10個(gè)字符的變量iddeclareidchar10注意,變量名前必須有前綴,以便與數(shù)據(jù)庫字段名相區(qū)分。,11,2.運(yùn)算符與表達(dá)式,算術(shù)運(yùn)算符見書P37,表2-2位運(yùn)算符見書P37,表2-3比較運(yùn)算符見書P38,表2-4邏輯運(yùn)算符見書P38,表2-5字符串運(yùn)算符在T-SQL中可以用算術(shù)運(yùn)算符的加號(hào)(+)做字符串的連接運(yùn)算。如abc+def的結(jié)果為abcdef。

5、,12,3.函數(shù),聚合函數(shù)加密函數(shù)游標(biāo)函數(shù)日期和時(shí)間函數(shù)數(shù)學(xué)函數(shù)元數(shù)據(jù)函數(shù),行集函數(shù)安全函數(shù)字符串函數(shù)類型轉(zhuǎn)換函數(shù)系統(tǒng)函數(shù)系統(tǒng)統(tǒng)計(jì)函數(shù),詳細(xì)介紹請(qǐng)參閱SQLServer相關(guān)使用手冊(cè)。,13,4.全局變量,全局變量是SQLServer系統(tǒng)預(yù)定義的,用于返回有關(guān)配置設(shè)置和系統(tǒng)運(yùn)行的信息。全局變量以做前綴。例如:SERVERNAME和FETCH_STATUS,局部變量?,14,5程序語句,注釋語句/*注釋*/,-注釋賦值語句給變量賦值復(fù)合語句可以定義一個(gè)語句塊,可用于嵌套條件語句循環(huán)語句執(zhí)行過程的語句主要用于執(zhí)行存儲(chǔ)過程等待語句掛起批處理,存儲(chǔ)過程或事物的執(zhí)行。PRINT語句向客戶輸出信息。RAIS

6、ERROR語句根據(jù)出錯(cuò)類型,輸出出錯(cuò)信息。返回語句無條件終止當(dāng)前的查詢等操作,返回調(diào)用程序,15,賦值語句,使用SELECT命令語句格式一:SELECTlocal_variable=expression,local_variable=expression語句格式二:SELECTlocal_variable=expression,local_variable=expressionFROM|使用SET命令的語句格式是:SETlocal_variable=expression,直接對(duì)變量進(jìn)行賦值,將查詢結(jié)果賦值給變量,local_variable是用DECLARE語句說明的局部變量expressio

7、n是與變量數(shù)據(jù)類型相匹配的表達(dá)式。,變量的賦值在Transact-SQL中不能像在一般的程序語言中一樣使用變量=變量值來給變量賦值,必須使用SELECT或SET命令來設(shè)定變量的值,其語法如下:SELECT局部變量表達(dá)式SET局部變量表達(dá)式例:給剛才定義的變量id并賦值selectid=10010001,17,WAITFOR語句,WAITFOR語句掛起批處理、存儲(chǔ)過程或事務(wù)的執(zhí)行。WAITFOR語句通常用于事務(wù)控制,例如當(dāng)已超過指定的時(shí)間間隔或到達(dá)一天中指定的時(shí)間再恢復(fù)程序的運(yùn)行。使程序延遲10秒執(zhí)行:WAITFORDELAY00:00:10使程序等到14時(shí)20分再開始執(zhí)行:WAITFORTIM

8、E14:20,18,PRINT語句,PRINT語句用于向客戶端輸出或返回定義的信息。PRINT語句的基本格式如下:PRINTmsg_str|local_variable|string_expr,msg_str是字符串常量local_variable可以是任何有效的字符數(shù)據(jù)類型變量(或者能夠隱式轉(zhuǎn)換為字符數(shù)據(jù)類型)string_expr是字符串表達(dá)式。,19,關(guān)系數(shù)據(jù)庫的三層模式結(jié)構(gòu),關(guān)系數(shù)據(jù)庫和SQL均支持三層模式結(jié)構(gòu)?;颈?、視圖、SQL存儲(chǔ)。外部數(shù)據(jù)庫、概念數(shù)據(jù)庫、存儲(chǔ)數(shù)據(jù)庫。如何定義基本表、視圖、SQL存儲(chǔ)?,20,SQLServer的數(shù)據(jù)庫存儲(chǔ)結(jié)構(gòu),每個(gè)SQLServer有3個(gè)基本系統(tǒng)

9、數(shù)據(jù)庫用于支持SQLServer的運(yùn)行和管理,所有用戶對(duì)象(包括基本表、視圖、存儲(chǔ)過程、觸發(fā)器等)都建立在用戶數(shù)據(jù)庫中,在一個(gè)SQLServer上可以建立多個(gè)用戶數(shù)據(jù)庫。數(shù)據(jù)庫的物理存儲(chǔ)基本是由SQLServer自動(dòng)管理的。,21,SQLServer的數(shù)據(jù)庫存儲(chǔ)結(jié)構(gòu),master數(shù)據(jù)庫:用于存儲(chǔ)所有系統(tǒng)級(jí)信息,包括所有的其他數(shù)據(jù)庫(如建立的用戶數(shù)據(jù)庫)的信息(包括數(shù)據(jù)庫的設(shè)置、對(duì)應(yīng)的操作系統(tǒng)文件名稱和位置等)、所有數(shù)據(jù)庫注冊(cè)用戶的信息以及系統(tǒng)配置設(shè)置等。,22,SQLServer的數(shù)據(jù)庫存儲(chǔ)結(jié)構(gòu),tempdb數(shù)據(jù)庫用于保存所有的臨時(shí)表和臨時(shí)存儲(chǔ)過程,它還可以滿足任何其它的臨時(shí)存儲(chǔ)要求。temp

10、db數(shù)據(jù)庫是全局資源。tempdb數(shù)據(jù)庫在SQLServer每次啟動(dòng)時(shí)都重新創(chuàng)建。,23,SQLServer的數(shù)據(jù)庫存儲(chǔ)結(jié)構(gòu),model數(shù)據(jù)庫model數(shù)據(jù)庫是一個(gè)模板數(shù)據(jù)庫,當(dāng)使用CREATEDATABASE命令建立新的數(shù)據(jù)庫時(shí),新數(shù)據(jù)庫的第一部分總是通過復(fù)制model數(shù)據(jù)庫中的內(nèi)容創(chuàng)建,剩余部分由空頁填充。由于SQLServer每次啟動(dòng)時(shí)都要?jiǎng)?chuàng)建tempdb數(shù)據(jù)庫,所以model數(shù)據(jù)庫必須一直存在于SQLServer系統(tǒng)中。,24,建立用戶數(shù)據(jù)庫,用戶數(shù)據(jù)存儲(chǔ)在用戶數(shù)據(jù)庫中建立用戶數(shù)據(jù)庫就是向操作系統(tǒng)申請(qǐng)存儲(chǔ)空間專門用來存儲(chǔ)用戶數(shù)據(jù)庫中的數(shù)據(jù)用來存儲(chǔ)數(shù)據(jù)庫數(shù)據(jù)的操作系統(tǒng)文件可以分為3類:主

11、文件次文件事務(wù)日志文件,數(shù)據(jù)庫存儲(chǔ)文件的構(gòu)成,存儲(chǔ)數(shù)據(jù)庫的啟動(dòng)信息和系統(tǒng)表,也可以用來存儲(chǔ)用戶數(shù)據(jù)。每個(gè)數(shù)據(jù)庫有且僅有一個(gè)主文件。建議主文件使用.mdf擴(kuò)展名。,主文件次文件事務(wù)日志文件,數(shù)據(jù)庫存儲(chǔ)文件的構(gòu)成,保存所有主文件中容納不下的數(shù)據(jù)。使用多個(gè)獨(dú)立磁盤驅(qū)動(dòng)器上的次文件,還可以將一個(gè)數(shù)據(jù)庫中的數(shù)據(jù)分布在多個(gè)物理磁盤上。每個(gè)數(shù)據(jù)庫有0或多個(gè)次文件。建議次文件使用.ndf擴(kuò)展名。,主文件次文件事務(wù)日志文件,數(shù)據(jù)庫存儲(chǔ)文件的構(gòu)成,用來保存恢復(fù)數(shù)據(jù)庫的日志信息。每個(gè)數(shù)據(jù)庫必須至少有一個(gè)事務(wù)日志文件(可以有多個(gè))。日志相當(dāng)于數(shù)據(jù)庫操作的“值班文件”,當(dāng)數(shù)據(jù)庫需要恢復(fù)時(shí)可以將數(shù)據(jù)庫恢復(fù)到最新的、一致的

12、狀態(tài)。建議日志文件使用.ldf擴(kuò)展名。,主文件次文件事務(wù)日志文件,CREATEDATABASE命令,建立數(shù)據(jù)庫的命令是CREATEDATABASE。在SQLServer中建立數(shù)據(jù)庫需要指定數(shù)據(jù)庫的名稱以及有關(guān)存儲(chǔ)文件的描述(包括由SQLServer使用的邏輯名,建立在磁盤上的操作系統(tǒng)文件名(含路徑),以及數(shù)據(jù)庫規(guī)模等),另外還有文件組和日志等有關(guān)信息。常用命令格式如下:CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,要建立的數(shù)據(jù)庫的名稱,數(shù)據(jù)庫名稱必須唯一,并且符合標(biāo)識(shí)符的規(guī)則;

13、database_name最多可以包含128個(gè)字符。,CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,指定用來存儲(chǔ)數(shù)據(jù)庫的操作系統(tǒng)文件(存儲(chǔ)在磁盤上的數(shù)據(jù)文件),該關(guān)鍵字后跟以逗號(hào)分隔的項(xiàng)列表。,CREATEDATABASE命令,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREAT

14、EDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,為數(shù)據(jù)庫指定主文件。一個(gè)數(shù)據(jù)庫只能有一個(gè)主文件,如果沒有指定PRIMARY,那么CREATEDATABASE語句中列出的第一個(gè)文件將成為主文件。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATAB

15、ASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,為定義的操作系統(tǒng)文件指定邏輯名稱logical_file_name,該名稱將由SQLServer管理和引用。logical_file_name在數(shù)據(jù)庫中必須唯一,并且符合標(biāo)識(shí)符的規(guī)則。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATABASE

16、database_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,指定要建立的操作系統(tǒng)文件名os_file_name,其中包含完整的路徑名和文件名,并且不能指定壓縮文件系統(tǒng)中的目錄。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATABASEdatabase_nameON,.,FI

17、LEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,指定所創(chuàng)建的操作系統(tǒng)文件的大?。╯ize),size的單位可以是KB(千字節(jié))、MB(兆字節(jié))、GB(千兆字節(jié))或TB(兆兆字節(jié)),默認(rèn)是MB。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATABASEdatabase_nameON,.,FILEGROU

18、Pfilegroup_name,.LOGON,.,CREATEDATABASE命令,指定定義的操作系統(tǒng)文件可以增長到的最大尺寸(max_size)。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,指定定義

19、的操作系統(tǒng)文件的增長增量,該項(xiàng)設(shè)置的結(jié)果不能超過MAXSIZE設(shè)置。,用于定義對(duì)應(yīng)的操作系統(tǒng)文件的屬性。包括:PRIMARY(NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment),CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,用于定義用戶文件組,filegroup_name是組名稱,后續(xù)的項(xiàng)列表給出該組的文件描述

20、。利用文件組可以將指定的邏輯組件存儲(chǔ)到指定的物理文件(在建立基本表的CREATETABLE命令中有對(duì)文件組的引用)。(詳見10.1),CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup_name,.LOGON,.,CREATEDATABASE命令,指定用來存儲(chǔ)數(shù)據(jù)庫日志的操作系統(tǒng)文件(日志文件),該關(guān)鍵字后跟以逗號(hào)分隔的項(xiàng)列表。如果沒有指定LOGON,將自動(dòng)創(chuàng)建一個(gè)日志文件,該文件使用系統(tǒng)生成的名稱,大小為數(shù)據(jù)庫中所有數(shù)據(jù)文件大小總和的25%。,CREATEDATABASEdatabase_nameON,.,FILEGROUPfilegroup

21、_name,.LOGON,.,CREATEDATABASE命令,建立數(shù)據(jù)庫的例子,使用CREATEDATABASE命令在SQLServer中建立“倉儲(chǔ)訂貨”數(shù)據(jù)庫,向操作系統(tǒng)申請(qǐng)的數(shù)據(jù)主文件的初始大小為10MB,最大為50MB,增量為5MB;日志文件的初始大小為5MB,最大為25MB,增量為5MB。,CREATEDATABASE倉儲(chǔ)訂貨ON(NAME=order_dat,FILENAME=c:mssqldataorderdat.mdf,SIZE=10,MAXSIZE=50,FILEGROWTH=5)LOGON(NAME=order_log,FILENAME=d:mssqllogorderlog

22、.ldf,SIZE=5MB,MAXSIZE=25MB,FILEGROWTH=5MB),注意:在建立數(shù)據(jù)庫之前,為操作系統(tǒng)文件指定的目錄路徑必須存在。,40,SQLServer的安全管理簡介,用戶分類登錄用戶管理數(shù)據(jù)庫用戶管理權(quán)限管理,41,1.用戶分類,SQLServer在安裝時(shí)默認(rèn)的系統(tǒng)管理員用戶是sa,系統(tǒng)管理員負(fù)責(zé)整個(gè)系統(tǒng)的管理,他可以創(chuàng)建數(shù)據(jù)庫、創(chuàng)建用戶、指定數(shù)據(jù)庫管理員(這里指某一個(gè)具體的數(shù)據(jù)庫的管理者)等。,應(yīng)用角度分類,42,2.登錄用戶管理,SQLServer又將用戶分為系統(tǒng)登錄用戶和數(shù)據(jù)庫用戶。一個(gè)用戶必須首先能夠登錄到數(shù)據(jù)庫管理系統(tǒng),然后才能去使用具體的數(shù)據(jù)庫。系統(tǒng)登錄用戶

23、由系統(tǒng)管理員負(fù)責(zé)管理,數(shù)據(jù)庫用戶由數(shù)據(jù)庫管理員負(fù)責(zé)管理。,系統(tǒng)角度分類,43,創(chuàng)建登錄用戶命令的基本格式,CREATELOGINlogin_nameWITHPASSWORD=password,login_name指定新建立的登錄用戶名WITHPASSWORD用來為新建立的登錄用戶指定口令,這個(gè)口令通常是臨時(shí)的,用戶登錄后可以自己更改口令。,44,例2-2:創(chuàng)建登錄用戶orders_man(初始口令是123456)。,CREATELOGINorders_manWITHPASSWORD=123456,45,3.數(shù)據(jù)庫用戶管理,數(shù)據(jù)庫用戶的管理通常是由數(shù)據(jù)庫管理員負(fù)責(zé)的,也可以由系統(tǒng)管理員代行數(shù)據(jù)庫管理員的職責(zé)。數(shù)據(jù)庫用戶管理包括建立新的數(shù)據(jù)庫用戶修改已有數(shù)據(jù)庫用戶刪除數(shù)據(jù)庫用戶。,46,建立新數(shù)據(jù)庫用戶的命令,CREATEUSERuser_nameLOGINlogin_nameWITHDEFAULT_SCHEMA=schema_name,user_name指定數(shù)據(jù)庫用戶名,如果沒有指定LOGIN則默認(rèn)自動(dòng)映射到同名的登錄用戶名;如果希望數(shù)據(jù)庫用戶名和登錄用戶名不一致,可以使用LOGINlogin_name指定登

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論