欧美色欧美亚洲高清在线观看,国产特黄特色a级在线视频,国产一区视频一区欧美,亚洲成a 人在线观看中文

  1. <ul id="fwlom"></ul>

    <object id="fwlom"></object>

    <span id="fwlom"></span><dfn id="fwlom"></dfn>

      <object id="fwlom"></object>

      Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)

      時(shí)間:2019-05-13 16:14:07下載本文作者:會(huì)員上傳
      簡(jiǎn)介:寫寫幫文庫(kù)小編為你整理了多篇相關(guān)的《Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)》,但愿對(duì)你工作學(xué)習(xí)有幫助,當(dāng)然你在寫寫幫文庫(kù)還可以找到更多《Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)》。

      第一篇:Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)

      Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)

      1.concat函數(shù)

      concat(字串1,字串2):將字符串

      1、字符串2 連在一起;CONCAT()只允許兩個(gè)參數(shù);

      換言之,一次只能將兩個(gè)字串串連起來(lái)。不過(guò),在Oracle中,我們可以用'||來(lái)一次串連

      多個(gè)字串。

      SQL Server中是:select id+’, ’+name from table1 where id=’1’ 結(jié)果就是:1,王華。

      2.ltrim與rtrim用法

      ltrim: 也就是按照y中的字符一個(gè)一個(gè)截掉x中的字符,并且是從左邊開始執(zhí)行的,只要遇

      到y(tǒng)中有的字符, x中的字符都會(huì)被截掉, 直到在x的字符中遇到y(tǒng)中沒(méi)有的字符為止函數(shù)命

      令才結(jié)束例如ltrim('abcdab','ab')結(jié)果并不是按‘a(chǎn)b’字符串來(lái)截?cái)?abcdba',而是分別按照字

      母a和b分別去找,分別按不是a和b的字符處開始截取。ltrim函數(shù)是從匹配函數(shù)開始之

      后出現(xiàn)在子串中任何字符都被屏蔽掉了;結(jié)果將是'cdab'。Rtrim用法與ltrim相反是從右邊截

      取。

      3.MONTHS_BETWEEN函 MONTHS_BETWEEN(x, y)用于計(jì)算x和y之間有幾個(gè)月。如果x在日歷中比y早,那

      么MONTHS_BETWEEN()就返回一個(gè)負(fù)數(shù)。

      第二篇:oracle維護(hù)常用sql語(yǔ)句(主要)

      1、oracle表空間利用率

      SELECT UPPER(F.TABLESPACE_NAME)“表空間名”,D.TOT_GROOTTE_MB “表空間大小(M)”,D.TOT_GROOTTE_MBF.TOTAL_BYTES)D.TOT_GROOTTE_MB * 100,2),'990.99')||'%' “使用比(%)”,F(xiàn).TOTAL_BYTES “空閑空間(M)”,F(xiàn).MAX_BYTES “最大塊(M)”

      FROM(SELECT TABLESPACE_NAME,ROUND(SUM(BYTES)/(1024 * 1024), 2)TOTAL_BYTES,ROUND(MAX(BYTES)/(1024 * 1024), 2)MAX_BYTES

      FROM SYS.DBA_FREE_SPACE

      GROUP BY TABLESPACE_NAME)F,(SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES)/(1024 * 1024), 2)TOT_GROOTTE_MB

      FROM SYS.DBA_DATA_FILES DD

      GROUP BY DD.TABLESPACE_NAME)D

      WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME

      ORDER BY F.TABLESPACE_NAME;查詢結(jié)果顯示:

      /

      非系統(tǒng)表空間使用和(M)

      select sum(“已使用空間(M)”)“已使用空間(M)和” from(SELECT UPPER(F.TABLESPACE_NAME)“表空間名”,D.TOT_GROOTTE_MB “表空間大小(M)”,D.TOT_GROOTTE_MBF.TOTAL_BYTES)/ D.TOT_GROOTTE_MB * 100,2),'990.99')||'%' “使用比(%)”,F(xiàn).TOTAL_BYTES “空閑空間(M)”,F(xiàn).MAX_BYTES “最大塊(M)”

      FROM(SELECT TABLESPACE_NAME,ROUND(SUM(BYTES)/(1024 * 1024), 2)TOTAL_BYTES,ROUND(MAX(BYTES)/(1024 * 1024), 2)MAX_BYTES

      FROM SYS.DBA_FREE_SPACE

      GROUP BY TABLESPACE_NAME)F,(SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES)/(1024 * 1024), 2)TOT_GROOTTE_MB

      FROM SYS.DBA_DATA_FILES DD

      GROUP BY DD.TABLESPACE_NAME)D

      WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME and F.TABLESPACE_NAME NOT IN('SYSAUX','USERS','UNDOTBS1','SYSTEM'))

      2、查詢當(dāng)前用戶默認(rèn)表空間的使用情況

      select tablespacename,sum(totalContent),sum(usecontent),sum(sparecontent),avg(sparepercent)from(SELECT b.file_id as id,b.tablespace_name as tablespacename,b.bytes as totalContent,(b.bytes-sum(nvl(a.bytes,0)))as usecontent,sum(nvl(a.bytes,0))as sparecontent,sum(nvl(a.bytes,0))/(b.bytes)*100 as sparepercent FROM dba_free_space a,dba_data_files b WHERE a.file_id=b.file_id and b.tablespace_name =(select default_tablespace from dba_users where username = user)

      group by b.tablespace_name,b.file_name,b.file_id,b.bytes)

      GROUP BY tablespacename;

      3、查詢所有用戶表使用大小的前三十名

      select * from(select segment_name,bytes from dba_segments where owner = USER order by bytes desc)where rownum <= 30

      4、查詢單張表的使用情況 select segment_name,bytes from dba_segments where segment_name = 'RE_STDEVT_FACT_DAY' and owner = USER

      RE_STDEVT_FACT_DAY是您要查詢的表名稱

      5、計(jì)算每個(gè)用戶占用的磁盤空間 select owner,sum(bytes)/1024/1024/1024 “Space(G)” from dba_segments group by owner order by 2;

      6、計(jì)算某個(gè)用戶占用的磁盤空間

      select owner,sum(bytes)/1024/1024/1024 “Space(G)” from dba_segments where owner='LIAOJL' group by owner;

      7、查看表空間的名稱及大?。ǚ峙浯笮。?

      select t.tablespace_name, round(sum(bytes/(1024*1024)),0)ts_size

      from dba_tablespaces t, dba_data_files d where t.tablespace_name = d.tablespace_name group by t.tablespace_name;

      8、查看表空間物理文件的名稱及大小(分配大?。?

      select tablespace_name, file_id, file_name,round(bytes/(1024*1024),0)total_space from dba_data_files order by tablespace_name;

      9、查看回滾段名稱及大小: select segment_name, tablespace_name, r.status,(initial_extent/1024)InitialExtent,(next_extent/1024)NextExtent, max_extents, v.curext CurExtent From dba_rollback_segs r, v$rollstat v Where r.segment_id = v.usn(+)order by segment_name;

      10、如何查看某個(gè)回滾段里面,跑的什么事物或者正在執(zhí)行什么sql語(yǔ)句: select d.sql_text,a.name from v$rollname a,v$transaction b,v$session c,v$sqltext d where a.usn=b.xidusn and b.addr=c.taddr and c.sql_address=d.address and c.sql_hash_value=d.hash_value and a.usn==2;(備注:你要看哪個(gè),就把usn=?寫成幾就行了)

      查看控制文件:

      SQL>select * from v$controlfile;

      查看日志文件:

      SQL> col member format a50 SQL>select * from v$logfile;

      11、如何查看當(dāng)前SQL*PLUS用戶的sid和serial#:

      SQL>select sid, serial#, status from v$session where audsid=userenv('sessionid');

      12、怎樣識(shí)別IO競(jìng)爭(zhēng)和負(fù)載平衡:

      SQL>col 文件名 format a35 SQL>select df.name 文件名, fs.phyrds 讀次數(shù), fs.phywrts 寫次數(shù),(fs.readtim/decode(fs.phyrds,0,-1,fs.phyrds))讀時(shí)間,(fs.writetim/decode(fs.phywrts,0,-1,fs.phywrts))寫時(shí)間 from v$datafile df, v$filestat fs where df.file#=fs.file# order by df.name

      13、查看有哪些用戶連接

      select s.osuser os_user_name, decode(sign(48command), 1, to_char(command), 'Action Code #' || to_char(command))action, status session_status,s.osuser os_user_name,s.sid,p.spid ,s.serial# serial_num,nvl(s.username, '[Oracle process]')user_name,s.terminal terminal,s.program program,st.value criteria_value from v$sesstat st,v$session s , v$process p

      where st.sid = s.sid and

      st.statistic# = to_number('38')and

      ('ALL' = 'ALL' or s.status = 'ALL')and p.addr = s.paddr order by st.value desc, p.spid asc, s.username asc, s.osuser asc

      21、監(jiān)控當(dāng)前數(shù)據(jù)庫(kù)誰(shuí)在運(yùn)行什么SQL語(yǔ)句: SELECT osuser, username, sql_text from v$session a, v$sqltext b where a.sql_address =b.address order by address, piece;

      Column type format a8

      22、查詢每個(gè)用戶執(zhí)行過(guò)的sql語(yǔ)句 select B.USER_NAME,C.OSUSER,C.MACHINE,C.PROGRAM,C.MODULE, A.USER_IO_WAIT_TIME,B.HASH_VALUE,C.SERVICE_NAME, A.SQL_TEXT from v$sqlarea a, v$open_cursor b,v$session c where A.ADDRESS=B.ADDRESS and C.USERNAME=B.USER_NAME order by C.OSUSER,B.USER_NAME

      第三篇:SQL語(yǔ)句常用函數(shù)

      SQL語(yǔ)句常用函數(shù)、字符轉(zhuǎn)換函數(shù)

      1、ASCII()

      返回字符表達(dá)式最左端字符的ASCII 碼值。在ASCII()函數(shù)中,純數(shù)字的字符串可不用‘’括起來(lái),但含其它字符的字符串必須用‘’括起來(lái)使用,否則會(huì)出錯(cuò)。

      2、CHAR()

      將ASCII 碼轉(zhuǎn)換為字符。如果沒(méi)有輸入0 ~ 255 之間的ASCII 碼值,CHAR()返回NULL。

      3、LOWER()和UPPER()

      LOWER()將字符串全部轉(zhuǎn)為小寫;UPPER()將字符串全部轉(zhuǎn)為大寫。

      4、STR()

      把數(shù)值型數(shù)據(jù)轉(zhuǎn)換為字符型數(shù)據(jù)。

      STR([,length[,]])

      length 指定返回的字符串的長(zhǎng)度,decimal 指定返回的小數(shù)位數(shù)。如果沒(méi)有指定長(zhǎng)度,缺省的length 值為10,decimal 缺省值為0。

      當(dāng)length 或者decimal 為負(fù)值時(shí),返回NULL;

      當(dāng)length 小于小數(shù)點(diǎn)左邊(包括符號(hào)位)的位數(shù)時(shí),返回length 個(gè)*; 先服從length,再取decimal ;

      當(dāng)返回的字符串位數(shù)小于length,左邊補(bǔ)足空格。

      二、去空格函數(shù)

      1、LTRIM()把字符串頭部的空格去掉。

      2、RTRIM()把字符串尾部的空格去掉。

      三、取子串函數(shù)

      1、left()

      LEFT(,)

      返回character_expression 左起 integer_expression 個(gè)字符。

      2、RIGHT()

      RIGHT(,)

      返回character_expression 右起 integer_expression 個(gè)字符。

      3、SUBSTRING()

      SUBSTRING(,,length)

      返回從字符串左邊第starting_ position 個(gè)字符起length個(gè)字符的部分。

      四、字符串比較函數(shù)

      1、CHARINDEX()

      返回字符串中某個(gè)指定的子串出現(xiàn)的開始位置。

      CHARINDEX(<’substring_expression’>,)

      其中substring _expression 是所要查找的字符表達(dá)式,expression 可為字符串也可為列名表達(dá)式。如果沒(méi)有發(fā)現(xiàn)子串,則返回0 值。

      此函數(shù)不能用于TEXT 和IMAGE 數(shù)據(jù)類型。

      2、PATINDEX()

      返回字符串中某個(gè)指定的子串出現(xiàn)的開始位置。

      PATINDEX(<’%substring _expression%’>,)其中子串表達(dá)式前后必須有百分號(hào)“%”否則返回值為0。

      與CHARINDEX 函數(shù)不同的是,PATINDEX函數(shù)的子串中可以使用通配符,且此函數(shù)可用于CHAR、VARCHAR 和TEXT 數(shù)據(jù)類型。

      五、字符串操作函數(shù)

      1、QUOTENAME()

      返回被特定字符括起來(lái)的字符串。

      QUOTENAME(<’character_expression’>[,quote_ character])其中quote_ character 標(biāo)明括字符串所用的字符,缺省值為“[]”。

      2、REPLICATE()

      返回一個(gè)重復(fù)character_expression 指定次數(shù)的字符串。

      REPLICATE(character_expression integer_expression)如果

      integer_expression 值為負(fù)值,則返回NULL。

      3、REVERSE()

      將指定的字符串的字符排列順序顛倒。

      REVERSE()其中character_expression 可以是字符串、常數(shù)或一個(gè)列的值。

      4、REPLACE()

      返回被替換了指定子串的字符串。

      REPLACE(,)用string_expression3 替換在string_expression1 中的子串string_expression2。

      5、SPACE()

      返回一個(gè)有指定長(zhǎng)度的空白字符串。

      SPACE()如果integer_expression 值為負(fù)值,則返回NULL。

      6、STUFF()

      用另一子串替換字符串指定位置、長(zhǎng)度的子串。

      STUFF(,,)

      如果起始位置為負(fù)或長(zhǎng)度值為負(fù),或者起始位置大于

      character_expression1 的長(zhǎng)度,則返回NULL 值。

      如果length 長(zhǎng)度大于character_expression1 中 start_ position 以右的長(zhǎng)度,則character_expression1 只保留首字符。

      六、數(shù)據(jù)類型轉(zhuǎn)換函數(shù)

      1、CAST()

      CAST( AS [ length ])

      2、CONVERT()

      CONVERT([ length ], [,style])

      1)data_type為SQL Server系統(tǒng)定義的數(shù)據(jù)類型,用戶自定義的數(shù)據(jù)類型不能在此使用。

      2)length用于指定數(shù)據(jù)的長(zhǎng)度,缺省值為30。

      3)把CHAR或VARCHAR類型轉(zhuǎn)換為諸如INT或SAMLLINT這樣的INTEGER類型、結(jié)果必須是帶正號(hào)或負(fù)號(hào)的數(shù)值。

      4)TEXT類型到CHAR或VARCHAR類型轉(zhuǎn)換最多為8000個(gè)字符,即CHAR或VARCHAR數(shù)據(jù)類型是最大長(zhǎng)度。

      5)IMAGE類型存儲(chǔ)的數(shù)據(jù)轉(zhuǎn)換到BINARY或VARBINARY類型,最多為8000個(gè)字符。

      6)把整數(shù)值轉(zhuǎn)換為MONEY或SMALLMONEY類型,按定義的國(guó)家的貨幣單位來(lái)處理,如人民幣、美元、英鎊等。

      7)BIT類型的轉(zhuǎn)換把非零值轉(zhuǎn)換為1,并仍以BIT類型存儲(chǔ)。

      8)試圖轉(zhuǎn)換到不同長(zhǎng)度的數(shù)據(jù)類型,會(huì)截短轉(zhuǎn)換值并在轉(zhuǎn)換值后顯示“+”,以標(biāo)識(shí)發(fā)生了這種截?cái)唷?/p>

      9)用CONVERT()函數(shù)的style 選項(xiàng)能以不同的格式顯示日期和時(shí)間。style 是將DATATIME 和SMALLDATETIME 數(shù)據(jù)轉(zhuǎn)換為字符串時(shí)所選用的由SQL Server 系統(tǒng)提供的轉(zhuǎn)換樣式編號(hào),不同的樣式編號(hào)有不同的輸出格式。

      七、日期函數(shù)

      1、day(date_expression)

      返回date_expression中的日期值

      2、month(date_expression)

      返回date_expression中的月份值

      3、year(date_expression)

      返回date_expression中的年份值

      4、DATEADD()

      DATEADD(,,)

      返回指定日期date 加上指定的額外日期間隔number 產(chǎn)生的新日期。

      5、DATEDIFF()

      DATEDIFF(,)

      返回兩個(gè)指定日期在datepart 方面的不同之處,即date2 超過(guò)date1的差距值,其結(jié)果值是一個(gè)帶有正負(fù)號(hào)的整數(shù)值。

      6、DATENAME()

      DATENAME(,)

      以字符串的形式返回日期的指定部分此部分。由datepart 來(lái)指定。

      7、DATEPART()

      DATEPART(,)

      以整數(shù)值的形式返回日期的指定部分。此部分由datepart 來(lái)指定。DATEPART(dd,date)等同于DAY(date)

      DATEPART(mm,date)等同于MONTH(date)

      DATEPART(yy,date)等同于YEAR(date)

      8、GETDATE()

      以DATETIME 的缺省格式返回系統(tǒng)當(dāng)前的日期和時(shí)間。

      八、統(tǒng)計(jì)函數(shù)

      AVG()-返回的平均價(jià)值

      count()-返回的行數(shù)

      first()-返回第一個(gè)值

      last()-返回最后一個(gè)值

      max()-返回的最大價(jià)值

      min()-返回最小的價(jià)值

      total()-返回的總和

      九、數(shù)學(xué)函數(shù)

      abs(numeric_expr)求絕對(duì)值

      ceiling(numeric_expr)取大于等于指定值的最小整數(shù) exp(float_expr)取指數(shù)

      floor(numeric_expr)小于等于指定值得最大整數(shù) pi()3.1415926.........power(numeric_expr,power)返回power次方

      rand([int_expr])隨機(jī)數(shù)產(chǎn)生器

      round(numeric_expr,int_expr)安int_expr規(guī)定的精度四舍五入 sign(int_expr)根據(jù)正數(shù),0,負(fù)數(shù),返回+1,0,-1 sqrt(float_expr)平方根

      十、系統(tǒng)函數(shù)

      suser_name()用戶登錄名

      user_name()用戶在數(shù)據(jù)庫(kù)中的名字 user用戶在數(shù)據(jù)庫(kù)中的名字 show_role()對(duì)當(dāng)前用戶起作用的規(guī)則

      db_name()數(shù)據(jù)庫(kù)名object_name(obj_id)數(shù)據(jù)庫(kù)對(duì)象名

      col_name(obj_id,col_id)列名

      col_length(objname,colname)列長(zhǎng)度

      valid_name(char_expr)是否是有效標(biāo)識(shí)符

      第四篇:Oracle SQL精妙SQL語(yǔ)句講解

      SQL*PLUS界面:

      登錄:輸入SQLPLUS回車;輸入正確的ORACLE用戶名并回車;輸入用戶口令并回車,顯示提示符:SQL>

      退出:輸入EXIT即可。

      2)命令的編輯與運(yùn)行:

      在命令提示符后輸入SQL命令并運(yùn)行,以分號(hào)結(jié)束輸入;以斜杠結(jié)束輸入;以空行結(jié)束輸入;

      利用SQL緩沖區(qū)進(jìn)行PL/SQL塊的編輯和運(yùn)行;

      利用命令文件進(jìn)行PL/SQL塊的編輯和運(yùn)行。

      數(shù)據(jù)庫(kù)查詢

      用SELECT語(yǔ)句從表中提取查詢數(shù)據(jù)。語(yǔ)法為

      SELECT [DISTINCT] {column1,column2,…} FROM tablename WHERE {conditions} GROUP BY {conditions} ORDER BY {expressions} [ASC/DESC];

      說(shuō)明:SELECT子句用于指定檢索數(shù)據(jù)庫(kù)的中哪些列,F(xiàn)ROM子句用于指定從哪一個(gè)表或視圖中檢索數(shù)據(jù)。

      SELECT中的操作符及多表查詢WHERE子句。(LIKE,IS,…)

      WHERE子句中的條件可以是一個(gè)包含等號(hào)或不等號(hào)的條件表達(dá)式,也可以是一個(gè)含有IN、NOT IN、BETWEEN、LIKE、IS NOT NULL等比較運(yùn)算符的條件式,還可以是由單一的條件表達(dá)通過(guò)邏輯運(yùn)算符組合成復(fù)合條件。

      ORDER BY 子句

      ORDER BY 子句使得SQL在顯示查詢結(jié)果時(shí)將各返回行按順序排列,返回行的排列順序由ORDER BY 子句指定的表達(dá)式的值確定。

      連接查詢

      利用SELECT語(yǔ)句進(jìn)行數(shù)據(jù)庫(kù)查詢時(shí),可以把多個(gè)表、視圖的數(shù)據(jù)結(jié)合起來(lái),使得查詢結(jié)果的每一行中包含來(lái)自多個(gè)表達(dá)式或視圖的數(shù)據(jù),這種操作被稱為連接查詢。

      連接查詢的方法是在SELECT命令的FROM子句中指定兩個(gè)或多個(gè)將被連接查詢的表或視圖,并且在WHERE子句告訴ORACLE如何把多個(gè)表的數(shù)據(jù)進(jìn)行合并。根據(jù)WHERE子句中的條件表達(dá)式是等還是不等式,可以把連接查詢分為等式連接和不等式連接。

      子查詢

      如果某一個(gè)SELECT命令(查詢1)出現(xiàn)在另一個(gè)SQL命令(查詢2)的一個(gè)子句中,則稱查詢1是查詢2的子查詢。

      基本數(shù)據(jù)類型(NUMBER,VARCHAR2,DATE)O

      RACEL支持下列內(nèi)部數(shù)據(jù)類型:

      VARCHAR2 變長(zhǎng)字符串,最長(zhǎng)為2000字符。

      NUMBER 數(shù)值型。

      LONG 變長(zhǎng)字符數(shù)據(jù),最長(zhǎng)為2G字節(jié)。

      DATE 日期型。

      RAW 二進(jìn)制數(shù)據(jù),最長(zhǎng)為255字節(jié)。

      LONG RAW 變長(zhǎng)二進(jìn)制數(shù)據(jù),最長(zhǎng)為2G字節(jié)。

      ROWID 二六進(jìn)制串,表示表的行的唯一地址。

      CHAR 定長(zhǎng)字符數(shù)據(jù),最長(zhǎng)為255。

      常用函數(shù)用法:

      一個(gè)函數(shù)類似于一個(gè)算符,它操作數(shù)據(jù)項(xiàng),返回一個(gè)結(jié)果。函數(shù)在格式上不同于算符,它個(gè)具有變?cè)?,可操?個(gè)、一個(gè)、二個(gè)或多個(gè)變?cè)问綖椋?/p>

      函數(shù)名(變?cè)?,變?cè)?,…?/p>

      函數(shù)具有下列一般類形:

      單行函數(shù)

      分組函數(shù)

      單行函數(shù)對(duì)查詢的表或視圖的每一行返回一個(gè)結(jié)果行。它有數(shù)值函數(shù),字符函數(shù),日期函數(shù),轉(zhuǎn)換函數(shù)等。

      分組函數(shù)返回的結(jié)果是基于行組而不是單行,所以分組函數(shù)不同于單行函數(shù)。在許多分組函數(shù)中可有下列選項(xiàng):

      DISTRNCT 該選項(xiàng)使分組函數(shù)只考慮變?cè)磉_(dá)式中的不同值。

      ALL該選項(xiàng)使分組函數(shù)考慮全部值,包含全部重復(fù)。

      全部分組函數(shù)(除COUNT(*)外)忽略空值。如果具有分組函數(shù)的查詢,沒(méi)有返回行或只有空值(分組函數(shù)的變?cè)≈档男校?,則分組函數(shù)返回空值。

      5、數(shù)據(jù)操縱語(yǔ)言命令:

      數(shù)據(jù)庫(kù)操縱語(yǔ)言(DML)命令用于查詢和操縱模式對(duì)象中的數(shù)據(jù),它不隱式地提交當(dāng)前事務(wù)。它包含UPDATE、INSERT、DELETE、EXPLAIN PLAN、SELECT和LOCK TABLE 等命令。下面簡(jiǎn)單介紹一下:

      1)UPDATE tablename SET {column1=expression1,column2=expression2,…} WHERE {conditions};

      例如:S QL>UPDATE EMP

      SET JOB =’MANAGER’

      WHERE ENAME=’MAPTIN’;

      SQL >SELECT * FROM EMP;

      UPDATE子句指明了要修改的數(shù)據(jù)庫(kù)是EMP,并用WHERE子句限制了只對(duì)名字(ENAME)為’MARTIN’的職工的數(shù)據(jù)進(jìn)行修改,SET子句則說(shuō)明修改的方式,即把’MARTION’的工作名稱(JOB)改為’MARAGER’.2)INSERT INTO tablename {column1,column2,…} VALUES {expression1,expression2,…};

      例如:SQL>SELECT INTO DEPT(DNAME,DEPTNO)

      VALUES(‘ACCOUNTING’,10)

      3)DELETE FROM tablename WHERE {conditions};

      例如:SQL>DELETE FROM EMP

      WHERE EMPNO = 7654;

      DELETE命令刪除一條記錄,而且DELETE命令只能刪除整行,而不能刪除某行中的部分?jǐn)?shù)據(jù).4)事務(wù)控制命令

      提交命令(COMMIT):可以使數(shù)據(jù)庫(kù)的修改永久化.設(shè)置AUTOCOMMIT為允許狀態(tài):SQL >SET AUTOCOMMIT ON;

      回滾命令(ROLLBACK):消除上一個(gè)COMMIT命令后的所做的全部修改,使得數(shù)據(jù)庫(kù)的內(nèi)容恢復(fù)到上一個(gè)COMMIT執(zhí)行后的狀態(tài).使用方法是:

      SQL>ROLLBACK;

      創(chuàng)建表、視圖、索引、同義詞、用戶。、表是存儲(chǔ)用戶數(shù)據(jù)的基本結(jié)構(gòu)。

      建立表主要指定義下列信息:

      列定義

      完整性約束

      表所在表空間

      存儲(chǔ)特性

      可選擇的聚集

      從一查詢獲得數(shù)據(jù)

      語(yǔ)法如下:CREATE TABLE tablename

      (column1 datatype [DEFAULT expression] [constraint], column1 datatype [DEFAULT expression] [constraint], ……)

      [STORAGE子句] [其他子句…];

      例如:

      SQL>CREATE TABLE NEW_DEPT(DPTNO NUMBER(2), DNAME CHAR(6), LOC CHAR(13);

      更改表作用:

      增加列

      增加完整性約束

      重新定義列(數(shù)據(jù)類型、長(zhǎng)度、缺省值)

      修改存儲(chǔ)參數(shù)或其它參數(shù)

      使能、使不能或刪除一完整性約束或觸發(fā)器

      顯式地分配一個(gè)范圍

      2)、視圖

      視圖是一個(gè)邏輯表,它允許操作者從其它表或視圖存取數(shù)據(jù),視圖本身不包含數(shù)據(jù)。視圖所基于的表稱為基表。

      引入視圖有下列作用:

      提供附加的表安全級(jí),限制存取基表的行或/和列集合。

      隱藏?cái)?shù)據(jù)復(fù)雜性。

      為數(shù)據(jù)提供另一種觀點(diǎn)。

      促使ORACLE的某些操作在包含視圖的數(shù)據(jù)庫(kù)上執(zhí)行,而不在另一個(gè)數(shù)據(jù)庫(kù)上執(zhí)行。

      3)、索引

      索引是種數(shù)據(jù)庫(kù)對(duì)象。對(duì)于在表或聚集的索引列上的每一值將包含一項(xiàng),為行提供直接的快速存取。在下列情況ORACLE可利用索引改進(jìn)性能:

      按指定的索引列的值查找行。

      按索引列的順序存取表。

      建立索引: CREATE [UNIQUE] INDEX indexname ON tablename(column ,。。);

      例如:SQL>CREAT INDEX IC_EMP

      ON CLUSTER EMPLOYEE

      4)、同義詞

      同義詞:為表、視圖、序列、存儲(chǔ)函數(shù)、包、快照或其它同義詞的另一個(gè)名字。使用同義詞為了安全和方便。對(duì)一對(duì)象建立同義詞可有下列好處:

      引用對(duì)象不需指出對(duì)象的持有者。

      引用對(duì)象不需指出它所位于的數(shù)據(jù)庫(kù)。

      為對(duì)象提供另一個(gè)名字。

      建立同義詞:

      CREATE SYNONYM symnon_name FOR [username.]tablename;

      例如:CREAT PUBLIC SYNONYM EMP

      FOR SCOTT.EMP @SALES

      5)、用戶

      CREATE USER username IDENTIFIED BY password;

      例如:SQL>CREATE USER SIDNEY

      IDENTIFIED BY CARTON;

      Oracle擴(kuò)展PL/SQL簡(jiǎn)介

      PL/SQL概述。

      PL/SQL是Oracle對(duì)SQL規(guī)范的擴(kuò)展,是一種塊結(jié)構(gòu)語(yǔ)言,即構(gòu)成一個(gè)PL/SQL程序的基本單位(過(guò)程、函數(shù)和無(wú)名塊)是邏輯塊,可包含任何數(shù)目的嵌套了快。這種程序結(jié)構(gòu)支持逐步求精方法解決問(wèn)題。一個(gè)塊(或子塊)將邏輯上相關(guān)的說(shuō)明和語(yǔ)句組合在一起,其形式為:

      DECLARE

      ---說(shuō)明

      BEGIN

      ---語(yǔ)句序列

      EXCEPTION

      ---例外處理程序

      END;

      它有以下優(yōu)點(diǎn):

      支持SQL;

      生產(chǎn)率高;

      性能好;

      可稱植性;

      與ORACLE集成.PL/SQL體系結(jié)構(gòu)

      PL/SQL運(yùn)行系統(tǒng)是種技術(shù),不是一種獨(dú)立產(chǎn)品,可認(rèn)為這種技術(shù)是PL/SQL塊和子程序的一種機(jī),它可接收任何有效的PL/SQL塊或子程序。如圖所示:

      PL/SQL機(jī)可執(zhí)行過(guò)程性語(yǔ)句,而將SQL語(yǔ)句發(fā)送到ORACLE服務(wù)器上的SQL語(yǔ)句執(zhí)行器。在ORACLE預(yù)編譯程序或OCI程序中可嵌入無(wú)名的PL/SQL塊。如果ORACLE具有PROCEDURAL選件,有名的PL/SQL塊(子程序)可單獨(dú)編譯,永久地存儲(chǔ)在數(shù)據(jù)庫(kù)中,準(zhǔn)備執(zhí)行。

      PL/SQL基礎(chǔ):

      PL/SQL有一字符集、保留字、標(biāo)點(diǎn)、數(shù)據(jù)類型、嚴(yán)密語(yǔ)法等,它與SQL有相同表示,現(xiàn)重點(diǎn)介紹。

      1)、數(shù)據(jù)類型:如下表所示

      數(shù)據(jù)類型 子類型

      純量類型 數(shù)值 BINARY_INTEGER NATURAL,POSITIVE

      NUMBER DEC,DECIMAL,DOUBLE PRECISION,PLOAT,INTEGER,INT,NUMERIC,REAL,SMALLINT

      字符 CHAR CHARACTER,STRING

      VARCHAR2 VARCHAR

      LONG

      LONG RAW

      RAW

      RAWID

      邏輯 BOOLEAN

      日期 DATE

      組合 類型 記錄 RECORD

      表 TABLE

      2)、變量和常量

      在PL/SQL程序中可將值存儲(chǔ)在變量和常量中,當(dāng)程序執(zhí)行時(shí),變量的值可以改變,而常量的值不能改變。

      3)、程序塊式結(jié)構(gòu):

      DECLARE

      變量說(shuō)明部分;

      BEGIN

      執(zhí)行語(yǔ)句部分;

      [EXCEPTION

      例外處理部分;] END;控制語(yǔ)句:

      分支語(yǔ)句:

      IF condition THEN

      Sequence_of_statements;

      END IF;

      IF condition THEN

      Sequence_of_statement1;

      ELSE

      Sequence_of_statement2;

      END IF;

      IF condition1 THEN

      Sequence_of_statement1;

      ELSIF condition2 THEN

      Sequence_of_statement2;

      ELSIF condition3 THEN

      Sequence_of_statement3;

      END IF;

      循環(huán)語(yǔ)句:

      LOOP

      Sequence_of_statements;

      IF condition THEN

      EXIT;

      END IF;

      END LOOP;

      WHILE condition LOOP

      Sequence_of_statements;

      END LOOP;

      FOR counter IN lower_bound..higher_bound LOOP

      Sequence_of_statements;

      END LOOP;

      子程序:

      存儲(chǔ)過(guò)程:

      CREATE PROCEDURE 過(guò)程名(參數(shù)說(shuō)明1,參數(shù)說(shuō)明2,[局部說(shuō)明]

      BEGIN

      執(zhí)行語(yǔ)句;

      END 過(guò)程名;

      。)IS。

      存儲(chǔ)函數(shù):

      CREATE FUNCTION 函數(shù)名(參數(shù)說(shuō)明1,參數(shù)說(shuō)明2。。)RETURN 類型 IS [局部說(shuō)明] BEGIN

      執(zhí)行語(yǔ)句;

      END 函數(shù)名

      Oracle SQL精妙SQL語(yǔ)句講解

      好東西,大家趕緊收藏吧~~~

      --行列轉(zhuǎn)換 行轉(zhuǎn)列

      DROP TABLE t_change_lc;CREATE TABLE t_change_lc(card_code VARCHAR2(3), q NUMBER, bal NUMBER);

      INSERT INTO t_change_lc

      SELECT '001' card_code, ROWNUM q, trunc(dbms_random.VALUE * 100)bal FROM dual CONNECT BY ROWNUM <= 4 UNION

      SELECT '002' card_code, ROWNUM q, trunc(dbms_random.VALUE * 100)bal FROM dual CONNECT BY ROWNUM <= 4;

      SELECT * FROM t_change_lc;

      SELECT a.card_code,SUM(decode(a.q, 1, a.bal, 0))q1,SUM(decode(a.q, 2, a.bal, 0))q2,SUM(decode(a.q, 3, a.bal, 0))q3,SUM(decode(a.q, 4, a.bal, 0))q4

      FROM t_change_lc a GROUP BY a.card_code ORDER BY 1;

      --行列轉(zhuǎn)換 列轉(zhuǎn)行

      DROP TABLE t_change_cl;CREATE TABLE t_change_cl AS SELECT a.card_code,SUM(decode(a.q, 1, a.bal, 0))q1,SUM(decode(a.q, 2, a.bal, 0))q2,SUM(decode(a.q, 3, a.bal, 0))q3,SUM(decode(a.q, 4, a.bal, 0))q4

      FROM t_change_lc a GROUP BY a.card_code ORDER BY 1;

      SELECT * FROM t_change_cl;

      SELECT t.card_code,t.rn q,decode(t.rn, 1, t.q1, 2, t.q2, 3, t.q3, 4, t.q4)bal

      FROM(SELECT a.*, b.rn

      FROM t_change_cl a,(SELECT ROWNUM rn FROM dual CONNECT BY ROWNUM <= 4)b)t ORDER BY 1, 2;

      --行列轉(zhuǎn)換 行轉(zhuǎn)列 合并

      DROP TABLE t_change_lc_comma;CREATE TABLE t_change_lc_comma AS SELECT card_code,'quarter_'||q AS q FROM t_change_lc;

      SELECT * FROM t_change_lc_comma;

      SELECT t1.card_code, substr(MAX(sys_connect_by_path(t1.q, ';')), 2)q

      FROM(SELECT a.card_code,a.q,row_number()over(PARTITION BY a.card_code ORDER BY a.q)rn

      FROM t_change_lc_comma a)t1 START WITH t1.rn = 1 CONNECT BY t1.card_code = PRIOR t1.card_code

      AND t1.rn1 = PRIOR t1.rn GROUP BY t1.card_code;

      SELECT * FROM t_change_cl_comma;SELECT t.card_code,substr(t.q,instr(';' || t.q, ';', 1, rn),instr(t.q || ';', ';', 1, rn)-instr(';' || t.q, ';', 1, rn))q

      FROM(SELECT a.card_code, a.q, b.rn

      FROM t_change_cl_comma a,(SELECT ROWNUM rn FROM dual CONNECT BY ROWNUM <= 100)b

      WHERE instr(';' || a.q, ';', 1, rn)> 0)t ORDER BY 1, 2;

      --實(shí)現(xiàn)一條記錄根據(jù)條件多表插入 DROP TABLE t_ia_src;CREATE TABLE t_ia_src AS SELECT 'a'||ROWNUM c1, 'b'||ROWNUM c2 FROM dual CONNECT BY ROWNUM<=5;DROP TABLE t_ia_dest_1;CREATE TABLE t_ia_dest_1(flag VARCHAR2(10), c VARCHAR2(10));DROP TABLE t_ia_dest_2;CREATE TABLE t_ia_dest_2(flag VARCHAR2(10), c VARCHAR2(10));DROP TABLE t_ia_dest_3;CREATE TABLE t_ia_dest_3(flag VARCHAR2(10), c VARCHAR2(10));

      SELECT * FROM t_ia_src;SELECT * FROM t_ia_dest_1;SELECT * FROM t_ia_dest_2;SELECT * FROM t_ia_dest_3;

      INSERT ALL WHEN(c1 IN('a1','a3'))THEN

      INTO t_ia_dest_1(flag,c)VALUES(flag1,c2)WHEN(c1 IN('a2','a4'))THEN

      INTO t_ia_dest_2(flag,c)VALUES(flag2,c2)ELSE INTO t_ia_dest_3(flag,c)VALUES(flag1||flag2,c1||c2)SELECT c1,c2, 'f1' flag1, 'f2' flag2 FROM t_ia_src;

      --如果存在就更新,不存在就插入用一個(gè)語(yǔ)句實(shí)現(xiàn) DROP TABLE t_mg;CREATE TABLE t_mg(code VARCHAR2(10), NAME VARCHAR2(10));

      SELECT * FROM t_mg;

      MERGE INTO t_mg a USING(SELECT 'the code' code, 'the name' NAME FROM dual)b ON(a.code = b.code)WHEN MATCHED THEN

      UPDATE SET a.NAME = b.NAME WHEN NOT MATCHED THEN

      INSERT(code, NAME)VALUES(b.code, b.NAME);

      --抽取/刪除重復(fù)記錄

      DROP TABLE t_dup;CREATE TABLE t_dup AS SELECT 'code_'||ROWNUM code, dbms_random.string('z',5)NAME FROM dual CONNECT BY ROWNUM<=10;

      INSERT INTO t_dup SELECT 'code_'||ROWNUM code, dbms_random.string('z',5)NAME FROM dual CONNECT BY ROWNUM<=2;

      SELECT * FROM t_dup;

      SELECT * FROM t_dup a WHERE a.ROWID <>(SELECT MIN(b.ROWID)FROM t_dup b WHERE a.code=b.code);

      SELECT b.code, b.NAME

      FROM(SELECT a.code,a.NAME,row_number()over(PARTITION BY a.code ORDER BY a.ROWID)rn

      FROM t_dup a)b WHERE b.rn > 1;

      --IN/EXISTS的不同適用環(huán)境--t_orders.customer_id有索引 SELECT a.*

      FROM t_employees a WHERE a.employee_id IN

      (SELECT b.sales_rep_id FROM t_orders b WHERE b.customer_id = 12);

      SELECT a.*

      FROM t_employees a WHERE EXISTS(SELECT 1

      FROM t_orders b

      WHERE b.customer_id = 12

      AND a.employee_id = b.sales_rep_id);

      --t_employees.department_id有索引 SELECT a.*

      FROM t_employees a WHERE a.department_id = 10

      AND EXISTS(SELECT 1 FROM t_orders b WHERE a.employee_id = b.sales_rep_id);

      SELECT a.*

      FROM t_employees a WHERE a.department_id = 10

      AND a.employee_id IN(SELECT b.sales_rep_id FROM t_orders b);

      --FBI DROP TABLE t_fbi;CREATE TABLE t_fbi AS SELECT ROWNUM rn, dbms_random.STRING('z',10)NAME , SYSDATE + dbms_random.VALUE * 10 dt FROM dual

      CONNECT BY ROWNUM <=10;

      CREATE INDEX idx_nonfbi ON t_fbi(dt);

      DROP INDEX idx_fbi_1;CREATE INDEX idx_fbi_1 ON t_fbi(trunc(dt));

      SELECT * FROM t_fbi WHERE trunc(dt)= to_date('2006-09-21','yyyy-mm-dd');

      --不建議使用

      SELECT * FROM t_fbi WHERE to_char(dt, 'yyyy-mm-dd')= '2006-09-21';

      --LOOP中的COMMIT/ROLLBACK DROP TABLE t_loop PURGE;create TABLE t_loop AS SELECT * FROM user_objects WHERE 1=2;

      SELECT * FROM t_loop;

      --逐行提交 DECLARE BEGIN

      FOR cur IN(SELECT * FROM user_objects)LOOP

      INSERT INTO t_loop VALUES cur;

      COMMIT;

      END LOOP;END;

      --模擬批量提交 DECLARE

      v_count NUMBER;BEGIN

      FOR cur IN(SELECT * FROM user_objects)LOOP

      INSERT INTO t_loop VALUES cur;

      v_count := v_count + 1;

      IF v_count >= 100 THEN

      COMMIT;

      END IF;

      END LOOP;

      COMMIT;END;

      --真正的批量提交 DECLARE

      CURSOR cur IS

      SELECT * FROM user_objects;

      TYPE rec IS TABLE OF user_objects%ROWTYPE;

      recs rec;BEGIN

      OPEN cur;

      WHILE(TRUE)LOOP

      FETCH cur BULK COLLECT

      INTO recs LIMIT 100;

      --forall 實(shí)現(xiàn)批量

      FORALL i IN 1..recs.COUNT

      INSERT INTO t_loop VALUES recs(i);

      COMMIT;

      EXIT WHEN cur%NOTFOUND;

      END LOOP;

      CLOSE cur;END;

      --悲觀鎖定/樂(lè)觀鎖定

      DROP TABLE t_lock PURGE;CREATE TABLE t_lock AS SELECT 1 ID FROM dual;

      SELECT * FROM t_lock;

      --常見的實(shí)現(xiàn)邏輯,隱含bug DECLARE

      v_cnt NUMBER;BEGIN

      --這里有并發(fā)性的bug

      SELECT MAX(ID)INTO v_cnt FROM t_lock;

      --here for other operation

      v_cnt := v_cnt + 1;

      INSERT INTO t_lock(ID)VALUES(v_cnt);

      COMMIT;END;

      --高并發(fā)環(huán)境下,安全的實(shí)現(xiàn)邏輯 DECLARE

      v_cnt NUMBER;BEGIN

      --對(duì)指定的行取得lock

      SELECT ID INTO v_cnt FROM t_lock WHERE ID=1 FOR UPDATE;

      --在有l(wèi)ock的情況下繼續(xù)下面的操作

      SELECT MAX(ID)INTO v_cnt FROM t_lock;

      --here for other operation

      v_cnt := v_cnt + 1;

      INSERT INTO t_lock(ID)VALUES(v_cnt);

      COMMIT;--提交并且釋放lock END;

      --硬解析/軟解析

      DROP TABLE t_hard PURGE;CREATE TABLE t_hard(ID INT);

      SELECT * FROM t_hard;

      DECLARE

      sql_1

      VARCHAR2(200);BEGIN

      --hard parse

      --java中的同等語(yǔ)句是 Statement.execute()

      FOR i IN 1..1000 LOOP

      sql_1 := 'insert into t_hard(id)values(' || i || ')';

      EXECUTE IMMEDIATE sql_1;

      END LOOP;

      COMMIT;

      --soft parse

      --java中的同等語(yǔ)句是 PreparedStatement.execute()

      sql_1

      := 'insert into t_hard(id)values(:id)';

      FOR i IN 1..1000 LOOP

      EXECUTE IMMEDIATE sql_1

      USING i;

      END LOOP;

      COMMIT;END;

      --正確的分頁(yè)算法

      SELECT *

      FROM(SELECT a.*, ROWNUM rn

      FROM(SELECT * FROM t_employees ORDER BY first_name)a

      WHERE ROWNUM <= 500)WHERE rn > 480;

      --分頁(yè)算法(why not this one)SELECT a.*, ROWNUM rn

      FROM(SELECT * FROM t_employees ORDER BY first_name)a WHERE ROWNUM <= 500 AND ROWNUM > 480;

      --分頁(yè)算法(why not this one)SELECT b.*

      FROM(SELECT a.*, ROWNUM rn

      FROM t_employees a

      WHERE ROWNUM < = 500

      ORDER BY first_name)b WHERE b.rn > 480;

      --OLAP--小計(jì)合計(jì) SELECT CASE

      WHEN a.deptno IS NULL THEN

      '合計(jì)'

      WHEN a.deptno IS NOT NULL AND a.empno IS NULL THEN

      '小計(jì)'

      ELSE

      '' || a.deptno

      END deptno,a.empno,a.ename,SUM(a.sal)total_sal

      FROM scott.emp a GROUP BY GROUPING SETS((a.deptno),(a.deptno, a.empno, a.ename),());

      --分組排序 SELECT a.deptno,a.empno,a.ename,a.sal,--可跳躍的rank

      rank()over(PARTITION BY a.deptno ORDER BY a.sal DESC)r1,--密集型rank

      dense_rank()over(PARTITION BY a.deptno ORDER BY a.sal DESC)r2,--不分組排序

      rank()over(ORDER BY sal DESC)r3

      FROM scott.emp a

      ORDER BY a.deptno,a.sal DESC;

      --當(dāng)前行數(shù)據(jù)和前/后n行的數(shù)據(jù)比較 SELECT a.empno,a.ename,a.sal,--上面一行

      lag(a.sal)over(ORDER BY a.sal DESC)lag_1,--下面三行

      lead(a.sal, 3)over(ORDER BY a.sal DESC)lead_3

      FROM scott.emp a ORDER BY a.sal DESC;

      一、數(shù)據(jù)表設(shè)計(jì)圖

      二、創(chuàng)建語(yǔ)句

      /*================*/ /* DBMS name: ORACLE Version 9i */ /* Created on: 2008-11-10 23:39:24 */ /*================*/

      alter table “emp”

      drop constraint FK_EMP_REFERENCE_DEPT;

      drop table “dept” cascade constraints;

      drop table “emp” cascade constraints;

      drop table “salgrade” cascade constraints;

      /*================*/ /* Table: “dept” */ /*================*/

      create table dept(deptno NUMBER(11)not null, dname VARCHAR2(15)not null, loc VARCHAR2(15)not null, constraint PK_DEPT primary key(deptno));

      /*================*/ /* Table: “emp” */ /*================*/

      create table emp(empno NUMBER(11)not null, deptno NUMBER(11), ename VARCHAR2(15)not null, sal NUMBER(11)not null, job VARCHAR2(15)not null, mgr NUMBER(11)not null, hirdate DATE not null, comm NUMBER(11)not null, constraint PK_EMP primary key(empno));

      /*================*/ /* Table: salgrade */ /*================*/

      create table salgrade(grade NUMBER(11)not null, losal NUMBER(11)not null, hisal NUMBER(11)not null, constraint PK_SALGRADE primary key(grade));

      alter table emp add constraint FK_EMP_REFERENCE_DEPT foreign key(deptno)references dept(deptno);

      三、測(cè)試要求及語(yǔ)句

      /** *公司工資最高的員工列表 子查詢 */

      select t.ename,t.sal from emp t where t.sal =(select max(sal)from emp)

      /** *查詢每一個(gè)員工的經(jīng)理人及自己的名字 */

      select e1.ename,e2.ename from emp e1 join emp e2 on(e1.mgr = e2.empno)

      /** *查詢公司平均薪水的等級(jí) */

      select s.grade from salgrade s where(select avg(t.sal)from emp t)between s.losal and s.hisal

      /** *求部門中那些人的工資最高 */

      select d.dname,ename,sal from(select t.deptno,ename,sal from(select deptno,max(sal)as max_sal from emp group by deptno)e join emp t on(e.deptno = t.deptno and t.sal = max_sal))et join dept d on(d.deptno = et.deptno)

      /** *查詢部門平均薪水的等級(jí) */

      select d.dname,avg_sal,grade from(select deptno,avg_sal,grade from(select deptno,avg(sal)as avg_sal from emp group by deptno)e join salgrade s on(e.avg_sal between s.losal and s.hisal))es join dept d on(es.deptno = d.deptno)

      /** *求部門的平均薪水等級(jí) */

      select deptno,avg(grade)from(select deptno,grade from emp e join salgrade s on(e.sal between s.losal and s.hisal))t group by t.deptno

      /** * 求那些人是經(jīng)理人 */

      select ename from emp e where empno in(select distinct mgr from emp)

      /** *不準(zhǔn)用組函數(shù) 求薪水的最高值 */

      select ename from emp where empno not in(select distinct e1.empno from emp e1 join emp e2 on(e1.sal

      /** *平均薪水最高的部門編號(hào)與名稱 */

      select d.deptno,dname from(select deptno,avg(sal)avg_sal from emp group by deptno)t1 join dept d on(d.deptno = t1.deptno)where avg_sal =(select max(avg_sal)from(select deptno,avg(sal)avg_sal from emp group by deptno)t2)

      /** *求平均薪水的等級(jí)最低的部門名稱 */

      select dname from dept d where d.deptno in(select deptno from(select deptno,grade from(select deptno,avg(sal)avg_sal from emp group by deptno)t1 join salgrade g on(avg_sal between g.losal and g.hisal))t2 where t2.grade =(select min(grade)from(select deptno,grade from(select deptno,avg(sal)avg_sal from emp group by deptno)t1 join salgrade g on(avg_sal between g.losal and g.hisal))t3))

      /** *求部門經(jīng)理人中平均薪水最低的部門名稱 */

      select d.dname,t1.avg_sal from dept d join(select deptno,avg(sal)avg_sal from(select e2.deptno,e2.ename,e2.sal from emp e1 join emp e2 on(e1.mgr = e2.empno))t group by deptno)t1 on(d.deptno = t1.deptno)where avg_sal =(select min(avg_sal)from(select deptno,avg(sal)avg_sal from(select e2.deptno,e2.ename,e2.sal from emp e1 join emp e2 on(e1.mgr = e2.empno))t group by deptno))/** *求必普通員工的最高薪水還要高的經(jīng)理人名稱 */

      select ename from(select e2.ename,e2.empno,e2.sal from emp e1 join emp e2 on(e1.mgr = e2.empno))t where t.sal >(select max(e.sal)from emp e where e.empno not in(select e1.mgr from emp e1 join emp e2 on(e1.mgr = e2.empno)))

      /** *求薪水最高的第6名到10名雇員 */

      SELECT * FROM(SELECT A.*, ROWNUM RN FROM(SELECT * FROM(select e1.ename,e1.sal from emp e1 order by e1.sal desc))A WHERE ROWNUM <= 10)WHERE RN >= 6

      第五篇:oracle復(fù)制表的sql語(yǔ)句

      oracle復(fù)制表的sql語(yǔ)句

      如下,表a是數(shù)據(jù)庫(kù)中已經(jīng)存在的表,b是準(zhǔn)備根據(jù)表a進(jìn)行復(fù)制創(chuàng)建的表:

      1、只復(fù)制表結(jié)構(gòu)的sql

      create table b as select * from a where 1<>12、即復(fù)制表結(jié)構(gòu)又復(fù)制表中數(shù)據(jù)的sql

      create table b as select * from a3、復(fù)制表的制定字段的sql

      create table b as select row_id,name,age from a where 1<>1//前提是row_id,name,age都是a表的列

      4、復(fù)制表的指定字段及這些指定字段的數(shù)據(jù)的sql

      create table b as select row_id,name,age from a

      以上語(yǔ)句雖然能夠很容易的根據(jù)a表結(jié)構(gòu)復(fù)制創(chuàng)建b表,但是a表的索引等卻復(fù)制不了,需要在b中手動(dòng)建立。

      5、insert into 會(huì)將查詢結(jié)果保存到已經(jīng)存在的表中

      insert into t2(column1, column2,....)select column1, column2,....from t1rm_data001.dbf'

      下載Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié)word格式文檔
      下載Oracle中的一些sql語(yǔ)句與函數(shù)總結(jié).doc
      將本文檔下載到自己電腦,方便修改和收藏,請(qǐng)勿使用迅雷等下載。
      點(diǎn)此處下載文檔

      文檔為doc格式


      聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),未作人工編輯處理,也不承擔(dān)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)有涉嫌版權(quán)的內(nèi)容,歡迎發(fā)送郵件至:645879355@qq.com 進(jìn)行舉報(bào),并提供相關(guān)證據(jù),工作人員會(huì)在5個(gè)工作日內(nèi)聯(lián)系你,一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。

      相關(guān)范文推薦

        Oracle SQL精妙SQL語(yǔ)句講解(5篇材料)

        好東西,大家趕緊收藏吧~~~ 轉(zhuǎn)自junsansi --行列轉(zhuǎn)換 行轉(zhuǎn)列 DROP TABLE t_change_lc; CREATE TABLE t_change_lc (card_code VARCHAR2, q NUMBER, bal NUMBER); INSERT......

        SQL語(yǔ)句經(jīng)典總結(jié)

        SQL語(yǔ)句經(jīng)典總結(jié) 一、入門 1、說(shuō)明:創(chuàng)建數(shù)據(jù)庫(kù) CREATE DATABASE database-name2、說(shuō)明:刪除數(shù)據(jù)庫(kù) drop database dbname 3、說(shuō)明:備份sql server --- 創(chuàng)建 備份數(shù)據(jù)的 device......

        經(jīng)典實(shí)用SQL語(yǔ)句大全總結(jié)

        經(jīng)典實(shí)用SQL語(yǔ)句大全總結(jié) [編輯語(yǔ)言]2015-05-26 19:56 本文導(dǎo)航 1、首頁(yè)2、11、說(shuō)明:四表聯(lián)查問(wèn)題: 本文是經(jīng)典實(shí)用SQL語(yǔ)句大全的介紹,下面是該介紹的詳細(xì)信息。 下列語(yǔ)句部分......

        SQL語(yǔ)句總結(jié)

        SQL語(yǔ)句總結(jié) 一、插入記錄 1. 插入固定的數(shù)值 語(yǔ)法: INSERT[INTO]表名[(字段列表)]VALUES(值列表) 示例1: Insert into Students values('Mary’,24,’mary@163.com’) 若沒(méi)有指......

        查詢Oracle正在執(zhí)行和執(zhí)行過(guò)的SQL語(yǔ)句

        查詢Oracle正在執(zhí)行和執(zhí)行過(guò)的SQL語(yǔ)句 --正在執(zhí)行的select a.username, a.sid,b.SQL_TEXT, b.SQL_FULLTEXT from v$session a, v$sqlarea bwhere a.sql_address = b.address......

        SQL中forXML語(yǔ)句用法總結(jié)

        -------raw模式:raw模式將查詢結(jié)果集中的每一行轉(zhuǎn)換為帶有通用標(biāo)識(shí)符row或可能提供元素名稱的xml元素。(將查詢結(jié)果集中的每一行轉(zhuǎn)換為row元素的屬性或row元素的子無(wú)素) ----......

        oracle常用語(yǔ)句

        Oracel 中常使用的語(yǔ)法(部分)Oracel 中常使用的語(yǔ)法 2、顯示當(dāng)前連接用戶 :SQL> show user 3、查看系統(tǒng)擁有哪些用戶 :SQL> select * from all_users; 4、新建用戶并授權(quán):SQL>......

        Oracle常用語(yǔ)句

        Oracle:1、創(chuàng)建user用戶: create user demo identified by demo account unlock默認(rèn)是lock; 2、權(quán)限回收和設(shè)置: grant connect|resource to demo;revoke connect|resource fr......