Oracle SQL語言基礎(chǔ)ppt課件_第1頁
Oracle SQL語言基礎(chǔ)ppt課件_第2頁
Oracle SQL語言基礎(chǔ)ppt課件_第3頁
Oracle SQL語言基礎(chǔ)ppt課件_第4頁
Oracle SQL語言基礎(chǔ)ppt課件_第5頁
已閱讀5頁,還剩69頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、SQL言語根底.本章學(xué)習(xí)目的 SQL言語是數(shù)據(jù)庫的規(guī)范言語。只需了解了SQL才干真正了解關(guān)系數(shù)據(jù)庫。本章將引見怎樣運(yùn)用“構(gòu)造化查詢言語SQL來操作數(shù)據(jù)庫。第二章 SQL言語根底 .本章內(nèi)容安排 2.1 SQL簡介 2.2 SQL根本語法 2.3 數(shù)據(jù)查詢言語DQL 2.4 數(shù)據(jù)支配言語DML 2.5 數(shù)據(jù)定義言語(DDL) 2.6 數(shù)據(jù)控制言語DCL 2.7 常用函數(shù). 2.1.2 SQL的優(yōu)點(diǎn) 2.1.3 操作界面 2.1.1 開展歷史 3.1 SQL簡介 . SQL言語是數(shù)據(jù)庫的中心言語。全稱是“構(gòu)造化查詢言語Structured Query Language,最早的是IBM的圣約瑟研討實(shí)

2、驗(yàn)室為其關(guān)系數(shù)據(jù)庫管理系統(tǒng)SYSTEMR開發(fā)的一種查詢言語,它的前身是SQUARE言語。 .1.非過程化言語 SQL是一個(gè)非過程化的言語,由于它一次處置一個(gè)記錄,對數(shù)據(jù)提供自動(dòng)導(dǎo)航。SQL允許用戶在高層的數(shù)據(jù)構(gòu)造上任務(wù),而不對單個(gè)記錄進(jìn)展操作,可操作記錄集。一切SQL語句接受集協(xié)作為輸入,前往集協(xié)作為輸出。SQL的集合特性允許一條SQL語句的結(jié)果作為另一條SQL語句的輸入。SQL不要求用戶指定對數(shù)據(jù)的存放方法。這種特性運(yùn)用戶更易集中精神于要得到的結(jié)果。2.1.2 SQL的優(yōu)點(diǎn) .2.1.2 SQL的優(yōu)點(diǎn)2.一致的言語 SQL可用于一切用戶的DB活動(dòng)模型,包括系統(tǒng)管理員、數(shù)據(jù)庫管理員、運(yùn)用程序員

3、、決策支持系統(tǒng)人員及許多其它類型的終端用戶。 SQL為許多義務(wù)提供了語句,包括:查詢數(shù)據(jù)在表中插入、修正和刪除記錄建立、修正和刪除數(shù)據(jù)對象控制對數(shù)據(jù)和數(shù)據(jù)對象的存取保證數(shù)據(jù)庫一致性和完好性.2.1.2 SQL的優(yōu)點(diǎn)3.是一切關(guān)系數(shù)據(jù)庫的公共言語由于一切主要的關(guān)系數(shù)據(jù)庫管理系統(tǒng)都支持SQL言語,用戶可將運(yùn)用SQL的技藝從一個(gè)RDBMS轉(zhuǎn)到另一個(gè),一切用SQL編寫的程序都是可以移植的。 .1SQL*PLUS界面:1登錄輸入SQLPLUS,再回車;接著輸入正確的Oracle用戶名并回車;輸入用戶口令并回車,會(huì)顯示提示符:SQL。2退出輸入EXIT即可。2語句的編輯與運(yùn)轉(zhuǎn)語句的編輯與運(yùn)轉(zhuǎn)可以在語句提示

4、符后輸入SQL語句并運(yùn)轉(zhuǎn)。執(zhí)行單條語句,以分號終了輸入;執(zhí)行程序塊以斜杠終了輸入,或者以空行終了輸入。也可以利用SQL緩沖區(qū)進(jìn)展PL/SQL塊的編輯和運(yùn)轉(zhuǎn),或利用語句文件進(jìn)展PL/SQL塊的編輯和運(yùn)轉(zhuǎn)。2.1.3 操作界面 .2.2.2 SQL言語的語法構(gòu)造 2.2.1 SQL言語的主要功能 3.2 SQL根本語法 .經(jīng)過SQL語句,程序員或數(shù)據(jù)庫管理員DBA可以做如下的主要任務(wù):1建立數(shù)據(jù)庫的表格,包括設(shè)置表格所可以運(yùn)用之空間。2改動(dòng)數(shù)據(jù)庫系統(tǒng)環(huán)境設(shè)置。3針對某個(gè)數(shù)據(jù)庫或表格,授予用戶存取權(quán)限。4對數(shù)據(jù)庫表格建立索引值。5修正數(shù)據(jù)庫表格構(gòu)造新建、刪除或是修正表格字段。6對數(shù)據(jù)庫進(jìn)展數(shù)據(jù)的新建

5、。7對數(shù)據(jù)庫進(jìn)展數(shù)據(jù)的刪除。8對數(shù)據(jù)庫進(jìn)展數(shù)據(jù)的修正。9對數(shù)據(jù)庫進(jìn)展數(shù)據(jù)的查詢。.2.2.2 SQL言語的語法構(gòu)造SQL語句是針對關(guān)系型數(shù)據(jù)庫所建立出來的語法表達(dá),所以SQL在這類數(shù)據(jù)庫中所發(fā)揚(yáng)的功能非常的強(qiáng),SQL的語句不多,而且其語法也相對較簡單。歸納起來,共有六大類:1第一類屬性詞Predicates2第二類聲明Declaration3第三類條件子句Clause4第四類運(yùn)算符Operator5第五類函數(shù)Function6第六類SQL語句Statement .2.3.2 復(fù)合查詢 2.3.1 根本查詢 2.3 數(shù)據(jù)查詢言語DQL2.3.3 集合函數(shù) .1DQL的根本構(gòu)造2SELECT 語句

6、的格式SELECT distinct 字段列表table.字段名字段名 as 別名 *集合函數(shù)字段名FROM 表名1 ,.WHERE.GROUP BY.HAVING.ORDER BY.2.3.1 根本查詢 . 3SELECT中的條件語句1FROM 條件子句SELECT fieldlist可以運(yùn)用算術(shù)運(yùn)算符 + - * /FROM tableexpression 2WHERE 條件子句SELECT fieldlistFROM tableexpressionWHERE criteria(后副:where子句中的運(yùn)算符)3“*,DISTINCT屬性詞用法 SELECT *|DISTINCT FROM

7、 table .4ORDER BY條件子句 SELECT fieldlist FROM tableWHERE selectcriteriaORDER BY fieldASC|DESC,field2ASC|DESC,.5GROUP BY 條件子句SELECT fieldlistFROM tableWHERE criteriaGROUP BY groupfieldlist6HAVING 條件子句 SELECT fieldlistFROM tableWHERE selectcriteriaGROUP BY groupfieldlistHAVING groupcriteria . where子句中的運(yùn)

8、算符: 1比較運(yùn)算符: = = 2范圍運(yùn)算符:NOTBetween .and 3列表運(yùn)算符:NOTIN(expression listvalue) 4方式匹配運(yùn)算符 like _ , % (5) NULL 運(yùn)算符:is not null 6邏輯運(yùn)算符:and or not (not 要與其他兩個(gè)共同運(yùn)用) 例如: WHERE (type = business OR type = psychology) AND NOT advance 5500 . 4本卷須知1字段名之間可以進(jìn)展算術(shù)運(yùn)算,例如:(字段名1*字段名2)/32查詢語句可以嵌套,例如:SELECTFROM 表名1 WHERE 字段1

9、in (SELECTFROM表名1,表名2, WHERE條件1 WHERE條件2);3查詢結(jié)果集的排序操作,默許的排序是升序ASC,降序是DESC。.1銜接查詢 銜接可以在SELECT 語句的FROM子句或WHERE子句中建立,在FROM子句中指出銜接時(shí)有助于將銜接操作與WHERE子句中的搜索條件區(qū)分開來。這樣就可以將多個(gè)表中的數(shù)據(jù)進(jìn)展有條件的查詢: select * from tablename1 , tablename2, where expre2.3.2 復(fù)合查詢.2結(jié)合查詢 UNION運(yùn)算符可以將兩個(gè)或兩個(gè)以上SELECT語句的查詢結(jié)果集合合并成一個(gè)結(jié)果集合顯示,即執(zhí)行結(jié)合查詢。UNI

10、ON的語法格式為:select_statementUNION ALL selectstatementUNION ALL selectstatementn3,外聯(lián)接查詢: 左外銜接查詢:left join 右外銜接查詢:right join 全外銜接查詢:full join 條件的指定用on4,內(nèi)銜接查詢: 第一種:在from后直接添加表名,中間用逗號隔開; 第二種:運(yùn)用 “join 銜接 ,條件的指定用“on5,自銜接: 就是將同一個(gè)表其不同的別名,使他在邏輯上成為兩張表.1統(tǒng)計(jì)字段值的數(shù)目函數(shù)COUNT用來統(tǒng)計(jì)一個(gè)表中有多少條記錄。Count(distinct/* 字段稱號)留意:函數(shù)COU

11、NT()沒有指定任何字段。這個(gè)語句計(jì)算表中一切記錄所數(shù)目,包括有空值的記錄。因此,不需求指定要被計(jì)算的特定字段。2計(jì)算字段的平均值函數(shù)AVG()可以前往一個(gè)字段中一切值的平均值。留意:函數(shù)AVG()只能對數(shù)值型字段運(yùn)用。這個(gè)函數(shù)在計(jì)算平均值時(shí)也忽略空值。2.3.3集合函數(shù).3計(jì)算字段值的和計(jì)算字段值的和運(yùn)用函數(shù)SUM()。留意:函數(shù)SUM()的前往值代表字段purchase_amount中一切值的總和。4前往最大值或最小值函數(shù)MAX()和函數(shù)MIN()分別用于前往最大值和最小值。留意:函數(shù)MIN()前往一個(gè)字段的一切值中的最小值。假設(shè)字段是空的,函數(shù)MIN()前往空值。.2.4.2 DELET

12、E語句2.4.1 INSERT語句 2.4 數(shù)據(jù)支配言語DML2.4.3 UPDATE語句.1INSERT語句格式INSERT語句用于往數(shù)據(jù)表里插入記錄。1插入單條記錄的語句格式為:INSERT INTO tablename(target.field1,target.field2,.)VALUES(value1,value2,.) 、2同時(shí)插入多條記錄的語句格式為:INSERT INTO tablename(target.field1,target.field2,)SELECT (source.field1,source.field2,)FROM tableexpression2.4.1 IN

13、SERT語句.2本卷須知1字符串類型的字段值必需用單引號括起來,例如:GOODDAY。2假設(shè)字段值里包含單引號需求進(jìn)展字符串轉(zhuǎn)換,把它交換成兩個(gè)單引號 。3字符串類型的字段值超越定義的長度會(huì)出錯(cuò),最好在插入前進(jìn)展長度校驗(yàn)。4日期字段的字段值可以用當(dāng)前數(shù)據(jù)庫的系統(tǒng)時(shí)間SYSDATE,準(zhǔn)確到秒。5INSERT時(shí)假設(shè)要用到從1開場自動(dòng)增長的序列號,應(yīng)該先建立一個(gè)序列號。 (6)在添加數(shù)據(jù)時(shí)可以運(yùn)用轉(zhuǎn)換函數(shù)添加指定的數(shù)據(jù)類型。 有to_char() to_date() to_number().1DELETE語句格式DELETE語句刪除數(shù)據(jù)表里的記錄。用DELETE語句刪除的記錄,無法再復(fù)原,所以條件設(shè)

14、置一定要正確。DELETE語句格式為:DELETE tablenameFROM tableexpressionWHERE criteria2.4.2 DELETE語句.2本卷須知1刪除記錄并不能釋放Oracle里被占用的數(shù)據(jù)塊表空間。它只把那些被刪除的數(shù)據(jù)塊標(biāo)成unused。2假設(shè)確實(shí)要?jiǎng)h除一個(gè)大表里的全部記錄,可以用TRUNCATE語句,它可以釋放占用的數(shù)據(jù)塊表空間,其語句格式為:TRUNCATE TABLE 表名;3此操作不可回退。. UPDATE 語句經(jīng)過條件的限制來修正特定的數(shù)據(jù)。 UPDATE語句格式為: UPDATE tablename SET newvalue FROM tabl

15、eexpression WHERE criteria; DML 語句對表都加上了行級鎖,確認(rèn)完成后,必需加上事物處置終了的語句COMMIT才干正式生效,否那么改動(dòng)不一定寫入數(shù)據(jù)庫里。假設(shè)想撤回這些操作,可以用語句ROLLBACK復(fù)原。2.4.3 UPDATE語句.2.5.2 ALTER語句 2.5.1 CREATE語句2.5 數(shù)據(jù)定義言語(DDL)2.5.3 DROP語句 2.5.4 TRUNCATE語句.1表的建立 表是存儲用戶數(shù)據(jù)的根本構(gòu)造。 建立表主要指定義以下信息: 列定義 完好性約束2.5.1 CREATE語句.字段數(shù)據(jù)類型:字符型:1、char n:定長字符串 長度120002、v

16、archar2(n) :變長字符串 長度140003、nchar(n):定長字符串 長度110004、nvarchar2(n)變長字符串 長度110005、long(n)變長字符串 長度2G數(shù)字型1、Number(p,s) :p為一切位數(shù),s為小數(shù)位數(shù) number 范圍 10的-38次方 到10的38次方 日期型1、date : 儲存從公元前4712/1/1到公元4712/12/31大對象數(shù)據(jù)類型 1、Blob(n):存4G的二進(jìn)制數(shù)據(jù) 2、Clob(n):存4G的字符數(shù)據(jù) 3、NClob(n):存4G unicode 的字符數(shù)據(jù) .1建立一個(gè)新表的語句格式可以利用CREATE TABLE語

17、句,來建立一個(gè)全新的表,但前提是:數(shù)據(jù)庫必需曾經(jīng)存在。語句格式為:CREATE TABLE tablename(field1 type(size)index1,field2 type(size)index2,.,nultifieldindex,.)constraint 約束名 primary key(列名)constraint 約束名 primary key(列名):不反復(fù),不能有null值 可以被外鍵援用,一個(gè)表中只能有一個(gè)主鍵constraint 約束名 unique (列名):字段中的數(shù)據(jù)不能反復(fù),可以被外鍵援用。constraint 約束名 foreign key(列名) refere

18、nces 主鍵表(主鍵列)中的數(shù)據(jù)必需來自于主鍵或者是獨(dú)一約束列數(shù)據(jù)。constraint 約束名 check(檢查表達(dá)式)constraint 約束名 default (默許值) 得到系統(tǒng)時(shí)間:sysdate.2本卷須知?jiǎng)?chuàng)建表時(shí)要把較小的不為空的字段放在前面,能夠?yàn)榭盏淖侄畏旁诤竺?。?chuàng)建表時(shí)可以用中文的字段名,但最好還是用英文的字段名。創(chuàng)建表時(shí)可以給字段加上默許值,例如DEFAULT SYSDATE。這樣每次插入和修正時(shí),不用程序操作這個(gè)字段都能得到動(dòng)作的時(shí)間。創(chuàng)建表時(shí)可以給字段加上約束條件。例如不允許反復(fù)UNIQUE,主鍵PRIMARY KEY。.2表索引的建立 索引是一種數(shù)據(jù)庫對象 ,他

19、是表和蔟相聯(lián)絡(luò)的構(gòu)造,可以是與表相關(guān)的SQL語句執(zhí)行更迅速,可以快速定位要查詢的信息,他對查詢結(jié)果每影響,但可以提高查詢速度,對于在表或聚集的索引列上的每一值將包含一項(xiàng),為行提供直接的快速存取。在以下情況下,Oracle可利用索引改良性能: 按指定的索引列的值查找行。按索引列的順序存取表。留意: 建立表的主鍵時(shí)候的約束可以自動(dòng)建索引 primary key - 獨(dú)一性索引 unique - 獨(dú)一性索引.表索引的建立主要采用的是CREATE INDEX語句。這個(gè)命令是對一個(gè)已存在的表建立索引,語句格式為:CREATEUNIQUEINDEX indexname ON tablename(field

20、1ASC|DESC,field2ASC|DESC,.).3視圖的建立視圖是一個(gè)邏輯表,它允許操作者從其它表或視圖存取數(shù)據(jù),視圖本身不包含數(shù)據(jù)。視圖所基于的表稱為基表。引入視圖有以下作用:提供附加的表平安級,限制存取基表的行或/和列集合。隱藏?cái)?shù)據(jù)復(fù)雜性。為數(shù)據(jù)提供另一種觀念。促使Oracle的某些操作在包含視圖的數(shù)據(jù)庫上執(zhí)行,而不在另一個(gè)數(shù)據(jù)庫上執(zhí)行。.建立視圖的語句格式為:CREATE VIEW viewname(字段列表) AS SELECT table1.field1,table2.field1 FROM table1,table2.;With read only.4同義詞的建立 同義詞為

21、表、視圖、序列、存儲函數(shù)、包、快照或其它同義詞的另一個(gè)名字。運(yùn)用同義詞為了平安和方便。對某一對象建立同義詞可有以下益處:援用對象不需指出對象的持有者。援用對象不需指出它所位于的數(shù)據(jù)庫。為對象提供另一個(gè)名字。建立同義詞運(yùn)用的語句格式為:CREATE SYNONYM symnon_name FOR username.tablename;.1ALTER語句格式用ALTER語句,可以修正表、索引,或?qū)σ晥D的字段重新設(shè)計(jì)。語句格式為:ALTER TABLE tablenameADD (COLUMN field type(size)|CONSTRAINT multifiedindex |DROP COLU

22、MN field|CONSTRAINT indexname2.5.2 ALTER語句.2ALTER語句的詳細(xì)用法1在表的后面添加一個(gè)字段,例如為: ALTER TABLE 表名 ADD (BOOK_SHU VARCHAR2(10) ) 2修正表里字段的定義描畫,例如為: ALTER TABLE 表名 MODIFY(BOOK_NAME“ NOT NULL)3給表里的字段加上約束條件,語句格式為: ALTER TABLE SCOTT.ZHOU1 ADD (CONSTRAINT ZHUJIAN PRIMARY KEY(book_name)修正表稱號: rename 舊表名 to 新表名.修正列的屬性

23、時(shí),需求留意以下幾條: 1、可以添加列的寬度或數(shù)字的精度。 2、減少列的寬度時(shí),列的取值要大于列值范 圍。 3、當(dāng)數(shù)據(jù)類型被修正時(shí),列值必需為空. 運(yùn)用DROP語句,可以刪除表,索引,視圖,同義詞,過程,函數(shù),數(shù)據(jù)庫鏈接等。可以恢復(fù),DROP語句的格式為:DROP TABLE table|INDEX index ON table例如: drop table biao 2.5.3 DROP語句. 運(yùn)用TRUNCATE語句,可以清空表里的一切記錄,保管表的構(gòu)造。TRUNCATE語句的格式為:TRUNCATE table 表名;2.5.4 TRUNCATE語句.2.6 數(shù)據(jù)控制言語1. COMMIT語句2. ROLLBACK語句 .事物控制實(shí)驗(yàn):兩個(gè)對比.C

溫馨提示

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

評論

0/150

提交評論