Oracle學習之總結
一、學會操作庫
首先在命令行:輸入sqlplus以sysassysdba登錄后操作
(在unix下先輸入suoracle切換到Oracle后,再輸入sqplus同上)1、怎樣創(chuàng)建一個庫?命令如下://創(chuàng)建表空間CreatetablespaceNMJYdatafile"D:\\app\\Administrator\\product\\11.2.0\\dbhome_1/oradata/NMJY.dbf"size200Mreuseautoextendonnext1280Kmaxsizeunlimited;//創(chuàng)建用戶并設置默認表空間
createuserNMJYidentifiedbynmjy201*defaulttablespaceNMJYquota10monusers;//授權
grantconnect,resource,dbatoNMJY;
grantsysdbatoNMJY;//此處授予最高權限commit;//提交操作2、怎樣刪除一個庫?命令如下://刪表空間
droptablespacelvyongincludingcontents;//刪用戶
dropusernmjycascade;3、怎樣備份和還原庫?
創(chuàng)建目錄語句:CREATEDIRECTORYdumdiras‘d:dump’;下面以備份和還原unix下的nmjy庫為例:--切換到oracle(windows下不需切換)su-oracle
--備份(此處路徑名是自己創(chuàng)建的dumdir,也可以自己直接輸入指定路徑)
expdpnmjy/nmjy201*@orclschemas=nmjyDIRECTORY=dumdirdumpfile=nmjy11117.dmp;
【說明:命令(expdp)庫(nmjy)/密碼(nmjy201*)@服務器(orcl)shemas=用戶(nmjy)(DIRECTORY)=dumdirdumpfile=文件名(nmjy11117.dmp)】
--還原
Impdpnmjy/nmjy201*@orclDIRECTORY=dumdirDUMPFILE=NMJY11117.DMP【說明同上】
二、怎樣從sqlserver導入表到oracle
在此借助開發(fā)工具VisualStudio201*:
1、打開VisualStudio201*,在工具欄中找到“連接到數據庫”,點擊后添加一個Oracle庫的連接,
在服務資源管理器中找到此連接,,右擊點‘導入表…’
路徑彈出如下頁面:
點新建一個連接,之后:
然后更改連接,選擇SqlServer,如下:
確定后,根據向導向后操作,到如下頁:
選擇要導入的表,防止和Oracle庫的已存在的表名沖動,統(tǒng)一在表名后加了個1,下一步檢查列類型,
把NCLOB類型轉為varchar2(4000),節(jié)省不需要的空間,然后點完成即導入。之后再通過PLSQL工具到把帶1的表中數據導入到對應表中
注:Oracle是嚴格區(qū)分大小寫的,凡牽扯到用戶ID之類的務必用Upper()轉換后導入。
說明:在Oracle庫之間導入數據的時候,也可用此辦法。
三、SqlServer和Oracle語句編碼比較
經過這一段時間的Oracle版本程序和數據庫的修改,總結如下:
1、在后臺C#代碼中拼Sql語句執(zhí)行的時候,用begin…end,中間是需執(zhí)行語句且以分號結尾2、凡是關于用戶ID查詢的,請轉換成大寫后再執(zhí)行查詢
3、新增用戶或子用戶的功能,也要注意把用戶ID轉成大寫后再插入數據庫4、在SqlServer中的字符串連接是用+,Oracle中的字符串連接是用||
5、SqlServer中的字符串轉換函數可以用convert、cast,Oracle中是用to_char、cast,為了通用,建議平時養(yǎng)成用cast的習慣
6、讀取前10行,SqlServer中是用selecttop10fromtable,Oracle是用select*fromtablewhererownum
擴展閱讀:有關Oracle學習總結
表xyzabc1mhj1mhjk1njk2uwe2uwert3qs4ads4adsaa
怎么刪掉第1、5、8條記錄?(字段a、b相同的幾條記錄只留一條,留下字段C較短的一條)
DELETEFROMLIANXI
WHERELENGTH(C)NOTIN(SELECTMIN(LENGTH(C))FROMLIANXIGROUPBYA,B)
oracle數據庫常用的命令集錦
今日開始研究oracle,搜索到了一個好東東,拿出來與大家一同分享。下面是摘抄的部分:[local]2[/local]
ORACLE相關語法及命令一、Oracle入門理論知識:
Oracle的物理組件有三個:
(1)數據文件數據文件是用于存儲數據庫數據的文件,如表、索引數據。每個Oracle數據庫有一個或多個物理數據文件,一個數據文件只能與一個數據庫關聯。(2)日志文件用于記錄對數據庫進行的修改信息,日志文件主要用于在數據庫出現故障時實施數據庫恢復。
(3)控制文件控制文件是記錄數據庫物理結構的二進制文件,每個Oracle數據庫都含有一個控制文件。
Oracle的邏輯組件:
表空間(TableSpace)表空間是數據庫最大的邏輯單位,一個數據庫至少包含一個表空間,一個表空間包含一個或多個段等等。段(Segment)段存在于表空間中,分成4類,數據段、索引段、回退段、臨時段。區(qū)(Extent)區(qū)是磁盤空間分配最小單位,由連續(xù)的數據塊組成,一個或多個區(qū)構成段,區(qū)只能存在于一個數據文件中。
數據塊(DataBlock)數據塊是數據庫中最小的數據組織單位與管理單位,Oracle數據庫中的數據存儲于數據塊中,取值范圍2K-64K之間。
模式(schema)模式是對用戶所創(chuàng)建的數據庫對象的總稱,又稱為用戶模式。概念:
內存Oracle內存結構包含以下兩個內存區(qū)。
1、系統(tǒng)全局區(qū)(SGA)實例啟動時分配該內存區(qū),是Oracle實例的一個基本組件。又稱為共享全局區(qū),它用來存儲數據庫信息,并由多個數據庫進程共享?煞譃楣蚕沓、數據緩沖區(qū)及日志緩沖區(qū)。
(1)共享池是對SQL、PL\\SQL程序進行語法分析、編譯、執(zhí)行的內存區(qū)域。共享池由庫緩存和數據字典緩存組成。其中,庫緩存含有最近執(zhí)行的SQL、PL\\SQL語句的分析碼和執(zhí)行計劃;數據字典緩存含有從數據字典中得到的表、索引、列定義和權限等信息。(2)數據緩沖區(qū)數據緩沖區(qū)用于存儲從磁盤數據文件中讀入的數據,所有用戶共享。(3)日志緩沖區(qū)日志記錄數據庫的所有修改信息,主要用于恢復數據。
2、程序全局區(qū)(PGA)服務器進程啟動時分配該內存區(qū)。PGA為非共享區(qū),只能單個進程使用,當一個用戶會話結束后,PGA釋放。
用戶進程(PGA)發(fā)送SQL語句到共享全局區(qū)(SGA),先在共享池的庫緩存中查詢是否存在所需的數據塊,如果存在就在數據字典中讀取相應的數據塊,如果不存在就由服務器進程(DBWR)來IO數據庫
語法知識:
創(chuàng)建表空間的語法如下:
CREATETABLESPACEtablespacenameDATAFILE"d:\\filename.DBF"[SIZEint[KB|MB]][AUTOEXTEND[OFF|ON]];
tablespacename是需創(chuàng)建的表空間名稱。
DATAFILE指定組成表空間的一個或多個數據文件,當有多個數據文件時使用逗號分隔。filename是表空間中數據文件的路徑和名稱。
SIZE指定文件的大小,用K指定千字節(jié)大小,用M指定兆字節(jié)大小。AUTOEXTEND子句用來啟用或禁用數據文件的自動擴展。Oracle默認用戶:
用戶名:sys默認密碼:chage_on_install用來管理擁有Oracle數據字典文件用戶名:system默認密碼:manager用來管理擁有數據字典視圖對象用戶名:scott默認密碼:tiger示例用戶,包括emp、dept等表連接Oracle:在控制臺下輸入sqlplus用戶名/密碼回車或sqlplusw回車相關命令:
disconn//退出當前登錄conn用戶名/密碼//連接Oracle
alteruser用戶名identifiedby密碼//修改用戶口令dropuser用戶名cascade;//刪除用戶
alteruser用戶名accountlock;//給某個用戶加鎖alteruser用戶名accountunlock;//給某個用戶解鎖ed回車://打開緩沖區(qū)
/回車://執(zhí)行緩沖區(qū)中的語句
createuser用戶名identifiedby密碼[passwordexpire]
[defaulttablespace表空間名][temporarytablespace臨時表空間名];//創(chuàng)建用戶相關權限:
grantconnecttoscott;//connect角色將允許用戶創(chuàng)建數據庫并在數據庫中創(chuàng)建表或其他對象grantresourcetoscott;//resource角色將允許用戶使用數據庫中的空間grantcreatesequencetoscott;//createsequence權限將允許用戶創(chuàng)建序列,此權限包含在connect連接角色中
grantselectonemptoscott;//將emp表的查詢權限授予用戶scott
grantupdate(vencode,venname)on表名toscott;//將特定列的更新權限授予用戶scottgrant權限on表名to用戶名withgrantoption;//接受該權限的用戶可以將此權限授予其他用戶
revokeselect,updateon表名from用戶名;//收回相應的權限二、SQL查詢和SQL函數SQL支持如下類別的命令:
數據定義語言:create(創(chuàng)建)、alter(更改)、drop(刪除)和truncate(截斷)命令。數據操縱語言:insert(插入)、select(選擇)、delete(刪除)和update(更新)命令。事務控制語言:commit(提交)、savepoint(保存點)和rollback(回滾)命令。數據控制語言:grant(授予)和revoke(回收)命令。數據類型:
char:長度在1到201*個字節(jié),聲明多少字節(jié)在內存中就占用多少字節(jié),輸入的值小于指定的長度時用空格填充。
varchar2:長度在1到4000個字節(jié),輸入的值是多少字節(jié),就占用多少字節(jié)。
long:長度在2GB,設置為此類型的列時,要注意:一個表中只有一列可以為long類型,long類型列不能定義為唯一約束或主鍵約束,不能建立索引,過程或存儲過程不能接受long類型的參數。
number(p,s):其中p為精度,表示數字的總位數,在1至38之間。s為范圍,表示小數點右邊數字的位數,在-84至127之間。
date:日期類型,sysdate為當前系統(tǒng)時間。格式為08-9月-07。
timestamp:用于存儲日期的年、月、日以及時間的時、分和秒。其中秒精確到小數點后6位,
systimestamp返回當前日期、時間。格式為08-9月-0704.08.30.000000下午。
raw:此數據類型用于存儲基于字節(jié)的數據,如二進制數據或字節(jié)串,該類型最多能存儲201*個字節(jié),可以建立索引。
longraw:此數據類型用于可變長度的二進制數據,最多能存儲2GB。long數據類型的所有限制對longraw數據類型也同樣有效。
lob又稱為"大對象"數據類型,最多能存儲4GB的非結構化信息。包括:
clob:clob代表CharacterLOB(字符LOB),它能存儲大量字符數據。如XML文檔。blob:blob代表BinaryLOB(二進制LOB),它能存儲較大的二進制對象,如圖形、視頻剪輯和聲音剪輯。
bfile:bfile代表BinaryFile(二進制文件),它能夠將二進制文件存儲在數據庫外部的操作系統(tǒng)文件中。偽列:
rowid:selectrowid,ename,fromscott.empwhereempno="7900";
rownum:select*fromscott.empwhererownumaltertable表名dropcolumn列名;//刪除列
truncatetable表名;//中刪除記錄而不刪除結構,不使用事務處理,因此無法回滾droptable表名;//刪除表及其全部數據
createtable新表名asselect*from表名where1=2;//用現有的表創(chuàng)建一個新表selectdeptno*2"NewNo",dname,locfromdept;//指定一個含有特殊字符(如空格)的列標題
commit;//提交事務
savepoint標記名;//標記事務點rollback;//回滾整個事務處理
rollbackto[savepoint]標記名;//回滾到事務中某個特定的保存點集合操作符:
union(聯合):此操作符返回兩個查詢選定的所有不重復的行。
語法selectordernofromorder_masterUNIONselectordernofromorder_detail;unionall(聯合所有):此操作符合并兩個查詢選定的所有行,包括重復的行。
語法:selectorderno,enamefromorder_masterUNIONALLselectorderno,pronamefromorder_detailorderby2;
注意:在兩個select語句中指定的列名不必相同,但數據類型必須匹配。也可以對聯合查詢的結果進行排序,使用OrderBy子句時,它必須放在最后
一個select語句之后,而且必須指定列索引來排序,而不是指定列名,列索引是從1開始的整數。上述語法便是以proname的索引排序
intersect(交集):此操作符只返回兩個查詢都有的行。
語法:selectordernofromorder_masterINTERSECTselectordernofromorder_detail;
minus(減集):此操作符中返回由第一個查詢選定但是第二個查詢中沒有選定的行,也就是在第一個查詢結果中排除第二個查詢結果中出現的行。
語法:selectordernofromorder_masterMINUSselectordernofromorder_detail;查詢尚未交付的訂單
連接(||)操作符:
語法:select("供應商"||venname||"的地址是"||venadd1||""||venadd2||""||venadd3)地址fromvendor_masterwherevencode="V002";將多個字符串合并為一個字符串。SQL函數:
1、日期函數:
add_months:此函數返回給指定的日期加上指定的月數后的日期值。語法為add_months(d,n),其中d是日期,n表示月數。
示例:selectadd_months(sysdate,2)fromdual;將當前時間加上2個月后的日期值。months_between:此函數返回兩個日期之間的月數。語法為months_between(d1,d2),其中d1和d2是日期,如果d1大于d2,則結果為正數;否則為負數。
last_day:此函數返回指定日期當月的最后一天的日期值,語法為last_day(d),其中d表示日期。
示例:selectlast_day(sysdate)fromdual;返回當前日期的月的最后一天,如果是9月就返回30-09月-07
round:此函數返回日期值,將日期四舍五入為格式模型指定的單位。語法為round(d,[fmt])。其中d是日期,fmt是格式模型。fmt是一個可選項,日期默認舍入為最靠近的那一天。如果指定格式為年"Year",則舍入到年的開始,即1月1日;如果格式為月"Month",則舍入到月的第一日;如果格式為周"Day",則舍入到最靠近的星期日。示例:selectround(sysdate,"month")fromdual;返回最接近的一個月。
next_day:此函數返回指定的下一個星期幾的日期。語法為next_day(d,day)。其中d表示日期,而day指周內任何一天。
示例:selectnext_day(sysdate,"星期日")fromdual;返回下一個星期日的日期,也可以用1表示,以此類推,星期一以2表示。
trunc:此函數將指定日期截斷為由格式模型指定的單位日期,與Round函數不同的是它只舍不入,語法為trunc(d,[fmt]),與round格式相同。
示例:selecttrunc(sysdate,"year")fromdual;返回當前年的第一天,也就是1月1日。示例:selecttrunc(sysdate,"day")fromdual;返回緊靠前面的星期日。如果為"201*年1月27日"就會返回"201*年1月23日"。
extract:此函數提取日期時間類型中的特定部分。語法為extract(fmtfromd),其中d是日期時間表達式,fmt是要提取的部分的格式。格式的取值可以是year,month,day,hour,minute,second,注意此處的格式不使用單引號。示例:selectextract(yearfromsysdate)fromdual;返回當前的年份。2、字符函數:
initcap(char):首字母大寫,示例:selectinitcap("hello")fromdual;輸出結果:Hello。lower(char):轉換為小寫,示例:selectlower("FUN")fromdual;輸出結果:fun。upper(char):轉換為大寫,示例:selectupper("sun")fromdual;輸出結果:SUN。
ltrim(char,set):左剪裁,示例:selectltrim("xyzadams","xyz")fromdual;輸出結果:adams。rtrim(char,set):右剪裁,示例:selectrtrim("xyzadams","ams")fromdual;輸出結果:xyzad。translate(char,from,to):按字符翻譯,示例:selecttranslate("jack","abcd","1234")fromdual;輸出結果:j13k。
replace(char,search_str,replace_str):字符串替換,示例:selectreplace("jackandjue","j","bl")fromdual;輸出結果:blackandblue。
instr(char,substr[,pos1,pos2]):查找子字串位置。
示例:selectinstr("vorldwide","d")fromdual;輸出結果:5。pos1為可選,表示從第幾個位置查找。pos2為可選,表示從第幾次出現的位置找。substr(char,pos,len):取子字符串,示例:selectsubstr("abcdefg",3,2)fromdual;輸出結果:cd。concat(char1,char2):連接字符串,示例:selectconcat("Hello","world")fromdual;輸出結果:Helloworld。
chr:此函數根據Ascii碼返回對應的字符,示例:selectchr(45788),chr(53671),chr(50167),chr(65)fromdual;輸出結果:曹學明A。
ascii:此函數返回GBK編碼值,示例:selectascii("曹")cao,ascii("學")xue,ascii("明")Mingfromdual;輸出結果:457885367150167。
lpad和rpad:示例:selectlpad("function",15,"=")fromdual;輸出結果:=======function。而rpad則相反,字符串填充在右邊。
trim:此函數從字符串的開頭或結尾(或開頭和結尾)剪裁特定的字符,默認剪裁空格。如果加上leading選項時與ltrim函數相似。指定trailing時和rtrim函數相似。示例:selecttrim(9from999992598899)fromdual;輸出結果:25988。
示例:selecttrim(leading9from999992598899)fromdual;輸出結果:2598899。示例:selecttrim(trailing9from999992598899)fromdual;輸出結果:9999925988。
length:此函數返回字符串的長度,示例:selectlength("frances")fromdual;輸出結果:7。decode:示例:selectdeptno,dname,decode(loc,"NEWYORK","紐約","BOSTON","波士頓")fromscott.dept;此示例將替換顯示loc列的結果,結果為"NEWYORK"的替換為"紐約","BOSTON"的替換為"波士頓"。
GREATEST/least:返回一組表達式中的最大值/最小值,即比較字符的編碼大小.示例:selectgreatest("AA","AB","AC")fromdual;輸出結果:AC。selectleast("AA","AB","AC")fromdual;輸出結果:AA。selectgreatest("啊","安","天")fromdual;輸出結果:天。selectleast("啊","安","天")fromdual;輸出結果:啊。3、數字函數:
abs(n):取絕對值,示例:selectabs(-15)fromdual;輸出結果:15。ceil(n):向上取整,示例:selectceil(44.778)fromdual;輸出結果:45。sign(n):取符號,示例:selectsign(-2)fromdual;輸出結果:-1。
floor(n):向下取整,示例:selectfloor(200.88)fromdual;輸出結果:200。power(m,n):m的n次冪,示例:selectpower(5,3)fromdual;輸出結果:125。mod(m,n):取余數,示例:selectmod(10,3)fromdual;輸出結果:1。
round(m,n):四舍五入,示例:selectround(100.256,2)fromdual;輸出結果:100.26。trunc(m,n):截斷,示例:selecttrunc(100.256,2)fromdual;輸出結果:100.25。sqrt(n):平方根,示例:selectsqrt(4)fromdual;輸出結果:2。4、轉換函數:
to_char(d|n[,fmt]):其中d是日期,n是數字,fmt指定日期或數字的格式。
示例:selectto_char(sysdate,"yyyy"年"fmmm"月"fmdd"日"hh24:mi:ss")fromdual;輸出結果:201*年9月09日20:44:27。
selectto_char(sysdate,"yyyy/mm/ddhh24:mi:ss")fromdual;selectto_char(sysdate,"yyyy-mm-ddhh24:mi:ss")fromdual;
selectto_char(sysdate,"yyyy"年"mm"月"dd"日"hh24"時"mi"分"ss"秒"")fromdual;示例:selectto_char(sal,"$99999")fromemp;輸出結果:$1600。
to_date(char[,fmt]):此函數將char或varchar2數據類型轉換為日期數據類型。示例:selectto_date("201*-12-06","yyyy-mm-dd")fromdual;輸出結果:06-12月-05。selectto_date("201*/08/1020:08:08","yyyy/mm/ddhh24:mi:ss")fromdual;selectto_date("201*-08-1020:08:08","yyyy/mm/ddhh24:mi:ss")fromdual;
selectto_date("201*年08月10日20時08分08秒","yyyy"年"mm"月"dd"日"hh24"時"mi"分"ss"秒"")fromdual;
to_number(char):此函數將包含數字的字符串轉換為number數據類型,通常不用這么做,因為Oracle可以對數字字符串進行隱式轉換。
示例:selectsqrt(to_number("100"))fromdual;輸出結果:10。5、其它函數:
nvl(expression1,expression2):如果expression1為NULL,則nvl返回expression2。
nvl2(expression1,expression2,expression3):如果expression1不是NULL,則nvl2返回expression2,如果expression1是NULL,則返回expression3。nullif(expr1,expr2):此函數比較兩個表達式,如果它們相等,則返回空值,否則返回expr1。nullif函數等價于以下的case表達式:
casewhenexpr1=expr2thennullelseexpr1end6、分組函數:
avg:此函數返回指定列值的平均值,示例:selectavg(sal)fromemp;輸出結果:2073.21429。min:此函數返回指定列值的最小值,示例:selectmin(sal)fromemp;輸出結果:800。max:此函數返回指定列值的最大值,示例:selectmax(sal)fromemp;輸出結果:5000。sum:此函數返回指定列值的總和,示例:selectsum(sal)fromemp;輸出結果:29025。count:此函數是為了計算行數,它可以接受3種不同的參數示例:selectcount(*)fromemp;輸出結果:14。示例:selectcount(列名)from表名;
示例:selectcount(distinct列名)from表名;
groupby:此子句用于將信息表劃分為組,按組進行聚合運算。select后面跟的列名只能是分組函數、groupby子句中出現的列或表達式。
示例:selectdeptno,max(sal)fromempgroupby(deptno);查出每個部門的最高工資。示例:selectdeptno,count(*),sum(sal)fromscott.empgroupbydeptno;//groupby主要用來對一組數進行統(tǒng)計
having:此子句用來指定groupby子句的檢索條件。
示例:selectdeptno,count(*),sum(sal)fromscott.empgroupbydeptnohavingcount(*)>=5;//having對分組統(tǒng)計再加限制條件
7、分析函數:只能出現在select列表或orderby子句中。
row_number:下面對所有員工的工資進行排名,即使工資相同,其排名也不能相同。示例:selectename,job,deptno,sal,row_number()over(orderbysaldesc)as排名fromscott.emp;
下面對所有員工的工資按部門進行排名,即使工資相同,排名也不同。
示例:selectename,job,deptno,sal,row_number()over(partitionbydeptnoorderbysaldesc)as排名fromscott.emp;
rank:此函數計算一個值在一組值中的排位,排位是以1開頭的連續(xù)整數,如果兩行的序數為1,則沒有序數2,下行的序數為3。
下面根據員工的工資和傭金對員工在每個部門中進行排位。相同的工資排位相同,并且排位不連續(xù)。
示例:selectename,sal,comm,deptno,rank()over(partitionbydeptnoorderbysaldesc,comm)排名fromscott.emp;
dense_rank:此函數計算一個行在一組有序行中的排位,排位是以1開頭的連續(xù)整數,具有相同值的排位相同,并且排位是連續(xù)的。
下面首先選擇所有在accounting或research部門中工作的員工的部門名稱、員工姓名和工資,
然后分別計算每個員工的工資在部門中的排位,相等的工次排位相同示例:selectd.dname,e.ename,e.sal,dense_rank()over(partitionbye.deptnoorderbye.saldesc)排名
fromempe,deptdwheree.deptno=d.deptno;
三、鎖和表分區(qū)
鎖定是數據庫用來控制共享資源并發(fā)訪問的機制。
Oracle提供以確保在多用戶環(huán)境下數據的完整性和一致性。鎖的兩種級別:(只有在提交或回滾后才能釋放鎖定)
(1)行級鎖:是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。在使用Insert、Update、Delete和Select...ForUpdate等語句時,Oracle會自動應用行級鎖定。Select...ForUpdate語法為:
Select...ForUpdate[OFcolumn_list][WAITn|NOWAIT]
其中:OF子句用于指定即將更新的列,即鎖定行上的特定列。WAIT子句指定等待其他用戶釋放鎖的秒數,防止無限期的等待。NOWAIT為不等待。示例1:演示如何鎖定deptno值為10的所有行。
select*fromdeptwheredeptno=10forupdateofdname,loc;
(2)表級鎖:將保護表數據,在事務處理過程中,表級鎖會限制對整個表的訪問。表級鎖用來限制對表執(zhí)行添加、更新和刪除等修改操作。語法:
LOCKTABLEINMODE[NOWAIT];其中:table_name是要被鎖定的表的名稱。lock_mode是鎖定的模式。表級鎖的模式:
1、行共享(ROWSHARE,RS):允許其他用戶訪問和鎖定該表,但是禁止排他鎖鎖定整個表。
2、行排他(ROWEXCLUSIVE,RX):與行共享模式相同,同時禁止其他用戶在此表上使用共享鎖。使用Select...Forupdate語句會自動應用行排他。
3、共享(SHARE,S):共享鎖將鎖定表,僅允許其他用戶查詢表中的行,但不允許插入、更新或刪除行。多個用戶可以同時在同一張表中放置共享鎖即允許資源共享。但是這樣極容易造成死鎖。
4、共享行排他(SHAREROWEXCLUSIVE,SRX):執(zhí)行比共享表鎖更多的限制。防止其他事務在表上應用共享鎖、共享行排他鎖以及排他鎖。
5、排他(EXCLUSIVE,X):對表執(zhí)行最大限制。除了允許其他用戶查詢該表的記錄,排他鎖防止其他事務對表做任何更改或在表上應用任何類型的鎖。示例2:演示如何以共享模式鎖定表。locktabledeptinsharemodenowait;表分區(qū)的優(yōu)點:
改善表的查詢性能;表更容易管理;便于備份和恢復;提高數據安全性。注意:要分區(qū)的表不能具有Long和LongRaw數據類型的列。四種分區(qū)方法:
1、范圍分區(qū):根據表的某個列或一組列的值范圍,決定將該數據存儲在哪個分區(qū)上。語法如下:
在CreateTable語句后增加
PARTITIONBYRANGE(column_name)(
PARTITIONpart1VALUELESSTHAN(range1)[TABLESPACEtbs1],PARTITIONpart2VALUELESSTHAN(range2)[TABLESPACEtbs2],....
PARTITIONpartNVALUELESSTHAN(MAXVALUE)[TABLESPACEtbsN]);
其中:column_name是以其為基礎創(chuàng)建范圍分區(qū)的列,特定行的該列值稱為分區(qū)鍵。part1...partN是分區(qū)的名稱。
range1...MAXVALUE是分區(qū)的邊界值。
tbs1...tbsN是分區(qū)所在的表空間,TABLESPACE子句是可選項。示例3:
createtablet_emp(
empnonumber(4),enamevarchar2(30),salnumber)
partitionbyrange(empno)(
partitione1valueslessthan(1000)tablespaceemp1,也可以than(to_date("201*-01-01","yyyy-mm-dd"))
partitione2valueslessthan(201*)tablespaceemp2,也可以than(to_date("201*-01-01","yyyy-mm-dd"))
partitione3valueslessthan(maxvalue)tablespaceemp3);
2、散列分區(qū):語法有兩種如下
PARTITIONBYHASH(column_name)
PARTITIONSnumber_of_partitions[STOREIN(tablespace_list)];或
PARTITIONBYHASH(column_name)(
PARTITIONpart1[TABLESPACEtbs1],PARTITIONpart2[TABLESPACEtbs2],...
PARTITIONpartN[TABLESPACEtbsN]);
其中:column_name是以其為基礎創(chuàng)建散列分區(qū)的列。
number_of_partitions是散列分區(qū)的數目,使用這種方法系統(tǒng)會自動生成分區(qū)的名稱。tablespace_list指定分區(qū)使用的表空間,如果分區(qū)數目比表空間的數目多,分區(qū)將會以循環(huán)的方式分配到表空間中。part1...partN是分區(qū)的名稱。
tbs1...tbsN是分區(qū)所在的表空間,TABLESPACE子句是可選項。示例4:自動分配4個散列分區(qū),
可以使用selectpartition_name,HIGH_VALUEfromuser_tab_partitionswheretable_name=upper("t_emp")查詢分區(qū)名createtablet_emp(
empnonumber(4),enamevarchar2(30),salnumber)
partitionbyhash(empno)partitions4;
3、復合分區(qū):是范圍分區(qū)和散列分區(qū)的結合。在創(chuàng)建復合分區(qū)時,先根據范圍對數據進行分區(qū),然后在這些分區(qū)內創(chuàng)建散列子分區(qū)。語法如下:
PARTITIONBYRANGE(column_name1)SUBPARTITIONBYHASH(column_name2)
SUBPARTITIONSnumber_of_partitions[STOREIN(tablespace_list)](
PARTITIONpart1VALUELESSTHAN(range1)[TABLESPACEtbs1],PARTITIONpart2VALUELESSTHAN(range2)[TABLESPACEtbs2],....
PARTITIONpartNVALUELESSTHAN(MAXVALUE)[TABLESPACEtbsN]);
其中:column_name1是以其為基礎創(chuàng)建范圍分區(qū)的列。column_name2是以其為基礎創(chuàng)建散列分區(qū)的列。number_of_partitions是要創(chuàng)建的子分區(qū)的數目。part1...partN是分區(qū)的名稱。
range1...MAXVALUE是范圍分區(qū)的邊界值
示例5:將雇員表先按照雇傭時間hiredate進行了范圍分區(qū),然后再把每個分區(qū)分為2個子hash分區(qū),此表一共是6個分區(qū)。createtablet_emp(
empnonumber(4),enamevarchar2(30),hiredatedate)
partitionbyrange(hiredate)subpartitionbyhash(empno)subpartitions2(
partitione1valueslessthan(to_date("201*0501","YYYYMMDD")),partitione2valueslessthan(to_date("201*1001","YYYYMMDD")),partitione3valueslessthan(maxvalue));
4、列表分區(qū):此分區(qū)允許用戶明確地控制行到分區(qū)的映射。語法如下:
PARTITIONBYLIST(column_name)(
PARTITIONpart1VALUES(values_list1),PARTITIONpart2VALUES(values_list2),....
PARTITIONpartNVALUES(DEFAULT));
其中:column_name是以其為基礎創(chuàng)建列表分區(qū)的列。part1...partN是分區(qū)的名稱。
values_list是對應分區(qū)的分區(qū)鍵值的列表。DEFAULT關鍵字允許存儲前面的分區(qū)不能存儲的記錄。示例6:
createtablet_emp1(
empnonumber(4),enamevarchar2(30),locationvarchar2(30))
partitionbylist(location)(
partitione1values("北京"),
partitione2values("上海","天津","重慶"),partitione3values("廣東","福建"),);
要查詢表分區(qū)中的數據行:select*fromtable_namePARTITION(p1);注:p1是分區(qū)名。分區(qū)維護操作:
1、添加分區(qū):ALTER...ADDPARTITION語句用于在現有的最后一個分區(qū)之后添加新的分區(qū)。
示例7:演示如何將名為E4的新分區(qū)添加到示例3中創(chuàng)建的t_emp表。ALTERTABLEt_empADDPARTITIONE4VALUESLESSTHAN(3000);在此請注意:上例公適用于已使用特定的鍵值定義了最后一個分區(qū)的表。如果要在表的開始或中間位置添加分區(qū),或者最高分區(qū)的分區(qū)
邊界是MAXVALUE,則應使用SPLITPARTITION語句。
2、刪除分區(qū):使用ALTERTABLE...DROPPARTITION語句。
示例8:演示了如何刪除t_emp表的E4分區(qū)。刪除分區(qū)時,分區(qū)中的數據也隨之刪除。ALTERTABLEt_empDROPPARTITIONE4;
3、截斷分區(qū):使用ALTERTABLE...TRUNCATEPARTITION語句來截斷分區(qū),只刪除表分區(qū)中的所有記錄。
示例9:演示了如何刪除t_emp表中e3的分區(qū)的所有記錄。ALTERTABLEt_empTRUNCATEPARTITIONe3;
4、合并分區(qū):可以將范圍分區(qū)或復合分區(qū)表的兩個相鄰分區(qū)連接起來。結果分區(qū)將繼承被合并的兩個分區(qū)的較高上界。語法如下:
ALTERTABLEtable_nameMERGEPARTITIONSpartitions_name,partitions_nameINTOPARTITIONpartition_name;
示例10:演示了如何將e1和e2合并成一個e2分區(qū)。
ALTERTABLEt_empMERGEPARTITIONSe1,e2INTOPARTITIONe2;
5、拆分分區(qū):使用SPLITPARTITION語句在表的開頭或中間添加分區(qū)。拆分分區(qū)允許用戶將一個分區(qū)拆分為兩個分區(qū)。語法如下:ALTERTABLEtable_nameSPLIYPARTITIONpartition_nameAT(value)INTO(PARTITIONpartition1,PARTITIONpartition2);
示例11:演示了如何將t_emp表中的e3分區(qū)拆分為e31和e32兩個分區(qū)。
ALTERTABLEt_empSPLITPARTITIONe3AT(Date"201*-01-01")INTO(PARTITIONe31,PARTITIONe32);
6、重新命名拆分后的分區(qū):
ALTERTABLEt_empRENAMEPARTITIONe31TOP3;ALTERTABLEt_empRENAMEPARTITIONe32TOP4;
可以查詢字典視圖user_tab_partitions來查看用戶所創(chuàng)建的分區(qū)的詳細信息示例12:selecttable_name,partition_name,high_valuefromuser_tab_partitions;
可以查詢字典視圖dba_tab_subpartitions來查看用戶所創(chuàng)建的子分區(qū)的詳細信息
示例13:selecttable_name,partition_name,subpartition_namefromdba_tab_subpartitions;
四、數據庫對象
表、視圖、序列、過程、函數、程序包,甚至其它同義詞都可以創(chuàng)建同義詞。
1、同義詞:私有同義詞、公有同義詞。私有同義詞只能被當前模式的用戶訪問。私有同義詞名稱不可與當前模式的對象名稱相同。要在自身的模式創(chuàng)建私有同義詞,
用戶必須擁有CreateSynonym系統(tǒng)權限。要在其它用戶模式創(chuàng)建私有同義詞,用戶必須擁有CreateAnySynonym系統(tǒng)權限。
公有同義詞可被所有的數據庫用戶訪問。要創(chuàng)建公有同義詞,用戶必須擁有CreatePublicSynonym系統(tǒng)權限。
創(chuàng)建私有同義詞語法:
Create[ORREPLACE]SYNONYM[schema.]synonym_nameFOR[schema.]object_name;其中:ORREPLACE表示在同義詞存在的情況下替換該同義詞。synonym_name表示要創(chuàng)建的同義詞的名稱。
object_name指定要為之創(chuàng)建同義詞的對象的名稱。示例1:createsynonyms_empforscott.emp;
創(chuàng)建公有同義詞語法:
CreatePUBLICSYNONYMsynonym_nameFOR[schema.]object_name;示例2:createpublicsynonymemp_synfromscott.emp;
可以查詢字典視圖User_Synonyms來查看用戶所創(chuàng)建的同義詞的詳細信息
刪除同義詞語法:DropSynonymssynonym_name;刪除公有同義詞加上一個Public此命令只刪除同義詞,不會刪除對應的表。
2、序列:是用來生成唯一、連續(xù)的整數的數據庫對象。序列通常用來自動生成主鍵或唯一鍵的值。
創(chuàng)建序列語法如下:
CreateSEQUENCEsequence_name[STARTWITHinteger][INCREMENTBYinteger]
[MAXVALUEinteger|NOMAXVALUE][MINVALUEinteger|NOMINVALUE][CYCLE|NOCYCLE]
[CACHEinterger|NOCACHE];
其中:STARTWITH是指定要生成的第一個序列號。對于升序序列,其默認值為序列的最小值。對于降序序列,其默認值為序列的最大值。
INCREMENTBY是用于指定序列號之間的間隔。其默認值為1。如果integer為正值,則生成的序列將按升序排列,否則按降序排列。MAXVALUE指定序列可以生成的最大值。
NOMAXVALUE這是默認選項,將升序序列的最大值設為10的27次冪,將降序序列的最大值設為-1。
MINVALUE指定序列的最小值。MINVALUE必須小于或等于STARTWITH的值,并且必須小于MAXVALUE。
NOMINVALUE這是默認選項,將升序序列的最小值設為1,將降序序列的最小值設為-10的26次冪。
CYCLE指定序列在達到最大值或最小值后,將繼續(xù)從頭開始生成值。
NOCYCLE這是默認選項。指定序列在達到最大值或最小值后,將不能再繼續(xù)生成值。CACHE使用CACHE選項可以預先分配一組序列號,并將其保留在內存中,這樣可以更快的訪問序列號。
NOCACHE此項則不會為加快速度而預先分配序列號。如果在創(chuàng)建序列時忽略了CACHE和NOCACHE選項,Oracle將默認緩存20個序列號。示例3:CreateSEQUENCEtoys_seqSTARTWITH10INCREMENTBY2MAXVALUE201*MINVALUE10NOCYCLECACHE30;
訪問序列:可以通過CURRVAL和NEXTVAL偽列來訪問該序列的值。示例4:演示從序列toys_seq中選擇值插入toys表中的toyid列。執(zhí)行成功將會在該表的toyid列插入值"P10"和"P12"。
INSERTINTOtoys(toyid,toyname,toyprice)values("p"||toys_seq.NEXTVAL,"TWENTY",25);INSERTINTOtoys(toyid,toyname,toyprice)values("p"||toys_seq.NEXTVAL,"MAGICPENCIL",75);
示例5:演示如何查看序列當前值
Selecttoys_seq.CURRVALfromdual;
更改序列:ALTERSEQUENCE命令用于設置或刪除MINVALUE或MAXVALUE、修改增量值、修改緩存中的序列號的數目。
修改序列語法如下:注意,不能修改序列的STARTWITH參數。在修改序列時,應注意升序序列的最小值應小于最大值。
ALTERSEQUENCE[schema.]sequence_name[INCREMENTBYinteger]
[MAXVALUEinteger|NOMAXVALUE][MINVALUEinteger|NOMINVALUE][CYCLE|NOCYCLE]
[CACHEinterger|NOCACHE];
示例6:演示如何設置一個新的MAXVALUE,并為toys_seq序列打開了CYCLE。ALTERSEQUENCEtoys_seqMAXVALUE5000CYCLE;
可以查詢字典視圖User_Sequences來查看用戶所創(chuàng)建的序列的詳細信息
刪除序列語法:DropSEQUENCEtoys_seq;
[local]2[/local]
友情提示:本文中關于《Oracle學習之總結》給出的范例僅供您參考拓展思維使用,Oracle學習之總結:該篇文章建議您自主創(chuàng)作。
來源:網絡整理 免責聲明:本文僅限學習分享,如產生版權問題,請聯系我們及時刪除。