史上最全SQL基礎(chǔ)知識(shí)總結(jié)_第1頁(yè)
史上最全SQL基礎(chǔ)知識(shí)總結(jié)_第2頁(yè)
史上最全SQL基礎(chǔ)知識(shí)總結(jié)_第3頁(yè)
史上最全SQL基礎(chǔ)知識(shí)總結(jié)_第4頁(yè)
史上最全SQL基礎(chǔ)知識(shí)總結(jié)_第5頁(yè)
已閱讀5頁(yè),還剩5頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

史上最全SQL基礎(chǔ)知識(shí)總結(jié)SQL概述1、什么是SQL==SQL(StructuredQueryLanguage)==是“結(jié)構(gòu)化查詢語言”,它是對(duì)關(guān)系型數(shù)據(jù)庫(kù)的操作語言。它可以應(yīng)用到所有關(guān)系型數(shù)據(jù)庫(kù)中,例如:MySQL、Oracle、SQLServer等。SQL標(biāo)準(zhǔn)(ANSI/ISO)有:SQL-92:1992年發(fā)布的SQL語言標(biāo)準(zhǔn);SQL:1999:1999年發(fā)布的SQL語言標(biāo)簽;SQL:2003:2003年發(fā)布的SQL語言標(biāo)簽;這些標(biāo)準(zhǔn)就與JDK的版本一樣,在新的版本中總要有一些語法的變化。不同時(shí)期的數(shù)據(jù)庫(kù)對(duì)不同標(biāo)準(zhǔn)做了實(shí)現(xiàn)。雖然SQL可以用在所有關(guān)系型數(shù)據(jù)庫(kù)中,但很多數(shù)據(jù)庫(kù)還都有標(biāo)準(zhǔn)之后的一些語法,我們可以稱之為“方言”。例如MySQL中的LIMIT語句就是MySQL獨(dú)有的方言,其它數(shù)據(jù)庫(kù)都不支持!當(dāng)然,Oracle或SQLServer都有自己的方言。2、語法要求SQL語句可以單行或多行書寫,以分號(hào)結(jié)尾;可以用空格和縮進(jìn)來來增強(qiáng)語句的可讀性;關(guān)鍵字不區(qū)別大小寫,建議使用大寫;SQL分類DDL(DataDefinitionLanguage):數(shù)據(jù)定義語言,用來定義數(shù)據(jù)庫(kù)對(duì)象:庫(kù)、表、列等;DML(DataManipulationLanguage):數(shù)據(jù)操作語言,用來定義數(shù)據(jù)庫(kù)記錄(數(shù)據(jù));DCL(DataControlLanguage):數(shù)據(jù)控制語言,用來定義訪問權(quán)限和安全級(jí)別;DQL(DataQueryLanguage):數(shù)據(jù)查詢語言,用來查詢記錄(數(shù)據(jù))DDL:數(shù)據(jù)定義語言基本操作查看所有數(shù)據(jù)庫(kù):showdatabases;切換數(shù)據(jù)庫(kù):usemydb1,切換到mydb1數(shù)據(jù)庫(kù);1.操作數(shù)據(jù)庫(kù)創(chuàng)建數(shù)據(jù)庫(kù):CREATEDATABASE[IFNOTEXISTS]mydb1;例如:CREATEDATABASEmydb1,創(chuàng)建一個(gè)名為mydb1的數(shù)據(jù)庫(kù)。如果這個(gè)數(shù)據(jù)已經(jīng)存在,那么會(huì)報(bào)錯(cuò)。例如CREATEDATABASEIFNOTEXISTSmydb1,在名為mydb1的數(shù)據(jù)庫(kù)不存在時(shí)創(chuàng)建該庫(kù),這樣可以避免報(bào)錯(cuò)。刪除數(shù)據(jù)庫(kù):DROPDATABASE[IFEXISTS]mydb1;例如:DROPDATABASEmydb1,刪除名為mydb1的數(shù)據(jù)庫(kù)。如果這個(gè)數(shù)據(jù)庫(kù)不存在,那么會(huì)報(bào)錯(cuò)。DROPDATABASEIFEXISTSmydb1,就算mydb1不存在,也不會(huì)的報(bào)錯(cuò)。修改數(shù)據(jù)庫(kù)編碼:ALTERDATABASEmydb1CHARACTERSETutf8修改數(shù)據(jù)庫(kù)mydb1的編碼為utf8。注意,在MySQL中所有的UTF-8編碼都不能使用中間的“-”,即UTF-8要書寫為UTF8。2.數(shù)據(jù)類型MySQL與Java、C一樣,也有數(shù)據(jù)類型MySQL中數(shù)據(jù)類型主要應(yīng)用在列上。常用類型:int:整型double:浮點(diǎn)型,例如double(5,2)表示最多5位,其中必須有2位小數(shù),即最大值為999.99;decimal:泛型型,在表單線方面使用該類型,因?yàn)椴粫?huì)出現(xiàn)精度缺失問題;char:固定長(zhǎng)度字符串類型;(當(dāng)輸入的字符不夠長(zhǎng)度時(shí)會(huì)補(bǔ)空格)varchar:固定長(zhǎng)度字符串類型;text:字符串類型;blob:字節(jié)類型;date:日期類型,格式為:yyyy-MM-dd;time:時(shí)間類型,格式為:hh:mm:sstimestamp:時(shí)間戳類型;3.操作表創(chuàng)建表CREATETABLE表名(列名列類型,列名列類型,......);例如,創(chuàng)建stu表CREATETABLEstu(sidCHAR(6),snameVARCHAR(20),ageINT,genderVARCHAR(10));查看表的結(jié)構(gòu)DESC表名;刪除表DROPTABLE表名;修改表添加列:給stu表添加classname列ALTERTABLEstuADD(classnamevarchar(100));修改列的數(shù)據(jù)類型:修改stu表的gender列類型為CHAR(2)ALTERTABLEstuMODIFYgenderCHAR(2);修改列名:修改stu表的gender列名為sexALTERTABLEstuchangegendersexCHAR(2);刪除列:刪除stu表的classname列ALTERTABLEstuDROPclassname;修改表名稱:修改stu表名稱為studentALTERTABLEstuRENAMETOstudent;DML:數(shù)據(jù)操作語言1.插入數(shù)據(jù)語法1:INSERTINTO表名(列名1,列名2,…);INSERTINTOstu(sid,sname,age,gender)VALUES('s_1001','zhangSan',23,'male');INSERTINTOstu(sid,sname)VALUES('s_1001','zhangSan');語法2:INSERTINTO表名VALUES(值1,值2,…);因?yàn)闆]有指定要插入的列,表示按創(chuàng)建表時(shí)列的順序插入所有列的值:INSERTINTOstuVALUES('s_1002','liSi',32,'female');注意:所有字符串?dāng)?shù)據(jù)必須使用單引用!2.修改數(shù)據(jù)語法:

UPDATE表名SET列名1=值1,…列名n=值n[WHERE條件];UPDATEstuSETsname=’zhangSanSan’,age=’32’,gender=’female’WHEREsid=’s_1001’;UPDATEstuSETsname=’liSi’,age=’20’WHEREage>50ANDgender=’male’;UPDATEstuSETsname=’wangWu’,age=’30’WHEREage>60ORgender=’female’;UPDATEstuSETgender=’female’WHEREgenderISNULLUPDATEstuSETage=age+1WHEREsname=’zhaoLiu’;3.刪除數(shù)據(jù)語法1:DELETEFROM表名[WHERE條件];DELETEFROMstuWHEREsid=’s_1001’003B;DELETEFROMstuWHEREsname=’chenQi’ORage>30;DELETEFROMstu;語法2:TRUNCATETABLE表名;TRUNCATETABLEstu;兩者之間的區(qū)別:雖然TRUNCATE和DELETE都可以刪除表的所有記錄,但有原理不同。DELETE的效率沒有TRUNCATE高!TRUNCATE其實(shí)屬性DDL語句,因?yàn)樗窍菵ROPTABLE,再CREATETABLE。而且TRUNCATE刪除的記錄是無法回滾的,但DELETE刪除的記錄是可以回滾的(回滾是事務(wù)的知識(shí)?。CL:數(shù)據(jù)控制語言1.創(chuàng)建用戶語法:CREATEUSER‘用戶名’@地址IDENTIFIEDBY'密碼';CREATEUSER‘user1’@localhostIDENTIFIEDBY‘123’;CREATEUSER‘user2’@’%’IDENTIFIEDBY‘123’;2.給用戶授權(quán)語法:GRANT權(quán)限1,…,權(quán)限nON數(shù)據(jù)庫(kù).*TO‘用戶名’@地址;GRANTCREATE,ALTER,DROP,INSERT,UPDATE,DELETE,SELECTONmydb1.*TOuser1@localhost;GRANTALLONmydb1.*TOuser2@localhost;3.撤銷授權(quán)語法:REVOKE權(quán)限1,…,權(quán)限nON數(shù)據(jù)庫(kù).*FROM‘用戶名’@地址;REVOKECREATE,ALTER,DROPONmydb1.*FROMuser1@localhost;4.查看用戶權(quán)限語法:SHOWGRANTSFOR‘用戶名’@地址;SHOWGRANTSFORuser1@localhost;5.刪除用戶語法:DROPUSER‘用戶名’@地址;DROPUSER‘user1’@localhost;6.修改用戶密碼(以root身份)語法:usemysql;alteruser'用戶名'@localhostidentifiedby'新密碼';DQL:數(shù)據(jù)查詢語言數(shù)據(jù)庫(kù)執(zhí)行DQL語句不會(huì)對(duì)數(shù)據(jù)進(jìn)行改變,而是讓數(shù)據(jù)庫(kù)發(fā)送結(jié)果集給客戶端。語法:select列名---->要查詢的列名稱from表名---->要查詢的表名稱where條件---->行條件groupby分組列---->對(duì)結(jié)果分組having分組條件---->分組后的行條件orderby排序列---->對(duì)結(jié)果分組limit起始行,行數(shù)---->結(jié)果限定創(chuàng)建數(shù)據(jù)庫(kù):Info,在Info下創(chuàng)建如下表:

學(xué)生表:stu:

CREATETABLEstu(sidCHAR(6),snameVARCHAR(50),ageINT,genderVARCHAR(50));INSERTINTOstuVALUES('S_1001','liuYi',35,'male');INSERTINTOstuVALUES('S_1002','chenEr',15,'female');INSERTINTOstuVALUES('S_1003','zhangSan',95,'male');INSERTINTOstuVALUES('S_1004','liSi',65,'female');INSERTINTOstuVALUES('S_1005','wangWu',55,'male');INSERTINTOstuVALUES('S_1006','zhaoLiu',75,'female');INSERTINTOstuVALUES('S_1007','sunQi',25,'male');INSERTINTOstuVALUES('S_1008','zhouBa',45,'female');INSERTINTOstuVALUES('S_1009','wuJiu',85,'male');INSERTINTOstuVALUES('S_1010','zhengShi',5,'female');INSERT

INTO

stu

VALUES('S_1011',

'xxx',

NULL,

NULL);雇員表:empCREATETABLEemp(empnoINT,enameVARCHAR(50),jobVARCHAR(50),mgrINT,hiredateDATE,salDECIMAL(7,2),commdecimal(7,2),deptnoINT);INSERTINTOempvalues(7369,'SMITH','CLERK',7902,'1980-12-17',800,NULL,20);INSERTINTOempvalues(7499,'ALLEN','SALESMAN',7698,'1981-02-20',1600,300,30);INSERTINTOempvalues(7521,'WARD','SALESMAN',7698,'1981-02-22',1250,500,30);INSERTINTOempvalues(7566,'JONES','MANAGER',7839,'1981-04-02',2975,NULL,20);INSERTINTOempvalues(7654,'MARTIN','SALESMAN',7698,'1981-09-28',1250,1400,30);INSERTINTOempvalues(7698,'BLAKE','MANAGER',7839,'1981-05-01',2850,NULL,30);INSERTINTOempvalues(7782,'CLARK','MANAGER',7839,'1981-06-09',2450,NULL,10);INSERTINTOempvalues(7788,'SCOTT','ANALYST',7566,'1987-04-19',3000,NULL,20);INSERTINTOempvalues(7839,'KING','PRESIDENT',NULL,'1981-11-17',5000,NULL,10);INSERTINTOempvalues(7844,'TURNER','SALESMAN',7698,'1981-09-08',1500,0,30);INSERTINTOe

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(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)論