天天看點

SQLServer和Oracle常用函數對比

<a href="http://www.cnblogs.com/ghd258/archive/2006/03/15/350804.html"></a>

SQLServer和Oracle常用函數對比

procedure Pro_SubPro

SQLServer和Oracle常用函數對比

(

SQLServer和Oracle常用函數對比

dw_in in varchar2,

SQLServer和Oracle常用函數對比

cur out pkg_general.ROW_CURSOR

SQLServer和Oracle常用函數對比

)

SQLServer和Oracle常用函數對比

as

SQLServer和Oracle常用函數對比

begin

SQLServer和Oracle常用函數對比

open cur for

SQLServer和Oracle常用函數對比

select yqmc from fle80 where dwbm=dw_in;

SQLServer和Oracle常用函數對比

end Pro_SubPro;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

procedure Pro_MainPro(

SQLServer和Oracle常用函數對比

dw_in in varchar2

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

mc NVARCHAR2(20);

SQLServer和Oracle常用函數對比

cur pkg_general.ROW_CURSOR;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

Pro_SubPro(dw_in,cur);

SQLServer和Oracle常用函數對比

fetch cur into mc;

SQLServer和Oracle常用函數對比

loop

SQLServer和Oracle常用函數對比

exit when cur%notfound;

SQLServer和Oracle常用函數對比

dbms_output.put_line(mc);

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

end loop;

SQLServer和Oracle常用函數對比

end Pro_MainPro;

數學函數

SQLServer和Oracle常用函數對比

在oracle 中distinct關鍵字可以顯示相同記錄隻顯示一條

SQLServer和Oracle常用函數對比

  1.絕對值

SQLServer和Oracle常用函數對比

  S:select abs(-1) value

SQLServer和Oracle常用函數對比

  O:select abs(-1) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  2.取整(大)

SQLServer和Oracle常用函數對比

  S:select ceiling(-1.001) value

SQLServer和Oracle常用函數對比

  O:select ceil(-1.001) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  3.取整(小)

SQLServer和Oracle常用函數對比

  S:select floor(-1.001) value

SQLServer和Oracle常用函數對比

  O:select floor(-1.001) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  4.取整(截取)

SQLServer和Oracle常用函數對比

  S:select cast(-1.002 as int) value

SQLServer和Oracle常用函數對比

  O:select trunc(-1.002) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  5.四舍五入

SQLServer和Oracle常用函數對比

  S:select round(1.23456,4) value 1.23460

SQLServer和Oracle常用函數對比

  O:select round(1.23456,4) value from dual 1.2346

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  6.e為底的幂

SQLServer和Oracle常用函數對比

  S:select Exp(1) value 2.7182818284590451

SQLServer和Oracle常用函數對比

  O:select Exp(1) value from dual 2.71828182

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  7.取e為底的對數

SQLServer和Oracle常用函數對比

  S:select log(2.7182818284590451) value 1

SQLServer和Oracle常用函數對比

  O:select ln(2.7182818284590451) value from dual; 1

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  8.取10為底對數

SQLServer和Oracle常用函數對比

  S:select log10(10) value 1

SQLServer和Oracle常用函數對比

  O:select log(10,10) value from dual; 1

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  9.取平方

SQLServer和Oracle常用函數對比

  S:select SQUARE(4) value 16

SQLServer和Oracle常用函數對比

  O:select power(4,2) value from dual 16

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  10.取平方根

SQLServer和Oracle常用函數對比

  S:select SQRT(4) value 2

SQLServer和Oracle常用函數對比

  O:select SQRT(4) value from dual 2

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  11.求任意數為底的幂

SQLServer和Oracle常用函數對比

  S:select power(3,4) value 81

SQLServer和Oracle常用函數對比

  O:select power(3,4) value from dual 81

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  12.取随機數

SQLServer和Oracle常用函數對比

  S:select rand() value

SQLServer和Oracle常用函數對比

  O:select sys.dbms_random.value(0,1) value from dual;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  13.取符号

SQLServer和Oracle常用函數對比

  S:select sign(-8) value -1

SQLServer和Oracle常用函數對比

  O:select sign(-8) value from dual -1

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  14.圓周率

SQLServer和Oracle常用函數對比

  S:SELECT PI() value 3.1415926535897931

SQLServer和Oracle常用函數對比

  O:不知道

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  15.sin,cos,tan 參數都以弧度為機關

SQLServer和Oracle常用函數對比

  例如:select sin(PI()/2) value 得到1(SQLServer)

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  16.Asin,Acos,Atan,Atan2 傳回弧度

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  17.弧度角度互換(SQLServer,Oracle不知道)

SQLServer和Oracle常用函數對比

  DEGREES:弧度-〉角度

SQLServer和Oracle常用函數對比

  RADIANS:角度-〉弧度

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

數值間比較

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  18. 求集合最大值

SQLServer和Oracle常用函數對比

  S:select max(value) value from

SQLServer和Oracle常用函數對比

  (select 1 value

SQLServer和Oracle常用函數對比

  union

SQLServer和Oracle常用函數對比

  select -2 value

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  select 4 value

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  select 3 value)a

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  O:select greatest(1,-2,4,3) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  19. 求集合最小值

SQLServer和Oracle常用函數對比

  S:select min(value) value from

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  O:select least(1,-2,4,3) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  20.如何處理null值(F2中的null以10代替)

SQLServer和Oracle常用函數對比

  S:select F1,IsNull(F2,10) value from Tbl

SQLServer和Oracle常用函數對比

  O:select F1,nvl(F2,10) value from Tbl

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  21.求字元序号

SQLServer和Oracle常用函數對比

  S:select ascii('a') value

SQLServer和Oracle常用函數對比

  O:select ascii('a') value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  22.從序号求字元

SQLServer和Oracle常用函數對比

  S:select char(97) value

SQLServer和Oracle常用函數對比

  O:select chr(97) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  23.連接配接

SQLServer和Oracle常用函數對比

  S:select '11'+'22'+'33' value

SQLServer和Oracle常用函數對比

  O:select CONCAT('11','22')  33 value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

23.子串位置 --傳回3

SQLServer和Oracle常用函數對比

  S:select CHARINDEX('s','sdsq',2) value

SQLServer和Oracle常用函數對比

  O:select INSTR('sdsq','s',2) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  23.模糊子串的位置 --傳回2,參數去掉中間%則傳回7

SQLServer和Oracle常用函數對比

  S:select patindex('%d%q%','sdsfasdqe') value

SQLServer和Oracle常用函數對比

  O:oracle沒發現,但是instr可以通過第四個參數控制出現次數

SQLServer和Oracle常用函數對比

  select INSTR('sdsfasdqe','sd',1,2) value from dual 傳回6

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  24.求子串

SQLServer和Oracle常用函數對比

  S:select substring('abcd',2,2) value

SQLServer和Oracle常用函數對比

  O:select substr('abcd',2,2) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  25.子串代替 傳回aijklmnef

SQLServer和Oracle常用函數對比

  S:SELECT STUFF('abcdef', 2, 3, 'ijklmn') value

SQLServer和Oracle常用函數對比

  O:SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  26.子串全部替換

SQLServer和Oracle常用函數對比

  S:沒發現

SQLServer和Oracle常用函數對比

  O:select Translate('fasdbfasegas','fa','我' ) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  27.長度

SQLServer和Oracle常用函數對比

  S:len,datalength

SQLServer和Oracle常用函數對比

  O:length

SQLServer和Oracle常用函數對比

  28.大小寫轉換 lower,upper

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  29.單詞首字母大寫

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  O:select INITCAP('abcd dsaf df') value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  30.左補空格(LPAD的第一個參數為空格則同space函數)

SQLServer和Oracle常用函數對比

  S:select space(10)+'abcd' value

SQLServer和Oracle常用函數對比

  O:select LPAD('abcd',14) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  31.右補空格(RPAD的第一個參數為空格則同space函數)

SQLServer和Oracle常用函數對比

  S:select 'abcd'+space(10) value

SQLServer和Oracle常用函數對比

  O:select RPAD('abcd',14) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  32.删除空格

SQLServer和Oracle常用函數對比

  S:ltrim,rtrim

SQLServer和Oracle常用函數對比

  O:ltrim,rtrim,trim

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  33. 重複字元串

SQLServer和Oracle常用函數對比

  S:select REPLICATE('abcd',2) value

SQLServer和Oracle常用函數對比

  O:沒發現

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  34.發音相似性比較(這兩個單詞傳回值一樣,發音相同)

SQLServer和Oracle常用函數對比

  S:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe')

SQLServer和Oracle常用函數對比

  O:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') from dual

SQLServer和Oracle常用函數對比

  SQLServer中用SELECT DIFFERENCE('Smithers', 'Smythers') 比較soundex的差

SQLServer和Oracle常用函數對比

  傳回0-4,4為同音,1最高

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

日期函數

SQLServer和Oracle常用函數對比

  35.系統時間

SQLServer和Oracle常用函數對比

  S:select getdate() value

SQLServer和Oracle常用函數對比

  O:select sysdate value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  36.前後幾日

SQLServer和Oracle常用函數對比

  直接與整數相加減

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  37.求日期

SQLServer和Oracle常用函數對比

  S:select convert(char(10),getdate(),20) value

SQLServer和Oracle常用函數對比

  O:select trunc(sysdate) value from dual

SQLServer和Oracle常用函數對比

  select to_char(sysdate,'yyyy-mm-dd') value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  38.求時間

SQLServer和Oracle常用函數對比

  S:select convert(char(8),getdate(),108) value

SQLServer和Oracle常用函數對比

  O:select to_char(sysdate,'hh24:mm:ss') value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

39.取日期時間的其他部分

SQLServer和Oracle常用函數對比

  S:DATEPART 和 DATENAME 函數 (第一個參數決定)

SQLServer和Oracle常用函數對比

  O:to_char函數 第二個參數決定

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  參數---------------------------------下表需要補充

SQLServer和Oracle常用函數對比

  year yy, yyyy

SQLServer和Oracle常用函數對比

  quarter qq, q (季度)

SQLServer和Oracle常用函數對比

  month mm, m (m O無效)

SQLServer和Oracle常用函數對比

  dayofyear dy, y (O表星期)

SQLServer和Oracle常用函數對比

  day dd, d (d O無效)

SQLServer和Oracle常用函數對比

  week wk, ww (wk O無效)

SQLServer和Oracle常用函數對比

  weekday dw (O不清楚)

SQLServer和Oracle常用函數對比

  Hour hh,hh12,hh24 (hh12,hh24 S無效)

SQLServer和Oracle常用函數對比

  minute mi, n (n O無效)

SQLServer和Oracle常用函數對比

  second ss, s (s O無效)

SQLServer和Oracle常用函數對比

  millisecond ms (O無效)

SQLServer和Oracle常用函數對比

  ----------------------------------------------

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  40.當月最後一天

SQLServer和Oracle常用函數對比

  S:不知道

SQLServer和Oracle常用函數對比

  O:select LAST_DAY(sysdate) value from dual

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  41.本星期的某一天(比如星期日)

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  O:SELECT Next_day(sysdate,7) vaule FROM DUAL;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  42.字元串轉時間

SQLServer和Oracle常用函數對比

  S:可以直接轉或者select cast('2004-09-08'as datetime) value

SQLServer和Oracle常用函數對比

  O:SELECT To_date('2004-01-05 22:09:38','yyyy-mm-dd hh24-mi-ss') vaule FROM DUAL;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  43.求兩日期某一部分的差(比如秒)

SQLServer和Oracle常用函數對比

  S:select datediff(ss,getdate(),getdate()+12.3) value

SQLServer和Oracle常用函數對比

  O:直接用兩個日期相減(比如d1-d2=12.3)

SQLServer和Oracle常用函數對比

  SELECT (d1-d2)*24*60*60 vaule FROM DUAL;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  44.根據內插補點求新的日期(比如分鐘)

SQLServer和Oracle常用函數對比

  S:select dateadd(mi,8,getdate()) value

SQLServer和Oracle常用函數對比

  O:SELECT sysdate+8/60/24 vaule FROM DUAL;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  45.求不同時區時間

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  O:SELECT New_time(sysdate,'ydt','gmt' ) vaule FROM DUAL;

SQLServer和Oracle常用函數對比
SQLServer和Oracle常用函數對比

  -----時區參數,北京在東8區應該是Ydt-------

SQLServer和Oracle常用函數對比

  AST ADT 大西洋标準時間

SQLServer和Oracle常用函數對比

  BST BDT 白令海标準時間

SQLServer和Oracle常用函數對比

  CST CDT 中部标準時間

SQLServer和Oracle常用函數對比

  EST EDT 東部标準時間

SQLServer和Oracle常用函數對比

  GMT 格林尼治标準時間

SQLServer和Oracle常用函數對比

  HST HDT 阿拉斯加?夏威夷标準時間

SQLServer和Oracle常用函數對比

  MST MDT 山區标準時間

SQLServer和Oracle常用函數對比

  NST 紐芬蘭标準時間

SQLServer和Oracle常用函數對比

  PST PDT 太平洋标準時間

SQLServer和Oracle常用函數對比

  YST YDT YUKON标準時間

SQLServer和Oracle常用函數對比

本文轉自高海東部落格園部落格,原文連結:http://www.cnblogs.com/ghd258/archive/2006/03/15/350804.html,如需轉載請自行聯系原作者