首頁 資料庫 mysql教程 SQLServer和Oracle的常用函数对比

SQLServer和Oracle的常用函数对比

Jun 07, 2016 pm 03:51 PM
oracle sqlserver 函數 對比 常用

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入 数学函数 1.绝对值 S:select abs(-1) value O:select abs(-1) value from dual 2.取整(大) S:select ceiling(-1.001) value O:select ceil(-1.001) value from dual 3.取整(小) S:select floor(-1

欢迎进入Oracle社区论坛,与200万技术人员互动交流 >>进入

数学函数
   1.绝对值
   S:select abs(-1) value
   O:select abs(-1) value from dual

  2.取整(大)
   S:select ceiling(-1.001) value
   O:select ceil(-1.001) value from dual

  3.取整(小)
   S:select floor(-1.001) value
   O:select floor(-1.001) value from dual

  4.取整(截取)
   S:select cast(-1.002 as int) value
   O:select trunc(-1.002) value from dual

  5.四舍五入
   S:select round(1.23456,4) value 1.23460
   O:select round(1.23456,4) value from dual 1.2346

  6.e为底的幂
   S:select Exp(1) value 2.7182818284590451
   O:select Exp(1) value from dual 2.71828182

  7.取e为底的对数
   S:select log(2.7182818284590451) value 1
   O:select ln(2.7182818284590451) value from dual; 1

  8.取10为底对数
   S:select log10(10) value 1
   O:select log(10,10) value from dual; 1

  9.取平方
   S:select SQUARE(4) value 16
   O:select power(4,2) value from dual 16

  10.取平方根
   S:select SQRT(4) value 2
   O:select SQRT(4) value from dual 2

  11.求任意数为底的幂
   S:select power(3,4) value 81
   O:select power(3,4) value from dual 81

  12.取随机数
   S:select rand() value
   O:select sys.dbms_random.value(0,1) value from dual;

  13.取符号
   S:select sign(-8) value -1
   O:select sign(-8) value from dual -1

  14.圆周率
   S:SELECT PI() value 3.1415926535897931
   O:不知道

  15.sin,cos,tan 参数都以弧度为单位
   例如:select sin(PI()/2) value 得到1(SQLServer)

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

  17.弧度角度互换(SQLServer,Oracle不知道)
   DEGREES:弧度-〉角度
   RADIANS:角度-〉弧度

数值间比较

  18. 求集合最大值
   S:select max(value) value from
   (select 1 value
   union
   select -2 value
   union
   select 4 value
   union
   select 3 value)a

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

  19. 求集合最小值
   S:select min(value) value from
   (select 1 value
   union
   select -2 value
   union
   select 4 value
   union
   select 3 value)a

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

  20.如何处理null值(F2中的null以10代替)
   S:select F1,IsNull(F2,10) value from Tbl
   O:select F1,nvl(F2,10) value from Tbl

  21.求字符序号
   S:select ascii('a') value
   O:select ascii('a') value from dual

  22.从序号求字符
   S:select char(97) value
   O:select chr(97) value from dual

  23.连接
   S:select '11'+'22'+'33' value
   O:select CONCAT('11','22')||33 value from dual

23.子串位置 --返回3
   S:select CHARINDEX('s','sdsq',2) value
   O:select INSTR('sdsq','s',2) value from dual

  23.模糊子串的位置 --返回2,参数去掉中间%则返回7
   S:select patindex('%d%q%','sdsfasdqe') value
   O:oracle没发现,但是instr可以通过第四个参数控制出现次数
   select INSTR('sdsfasdqe','sd',1,2) value from dual 返回6

  24.求子串
   S:select substring('abcd',2,2) value
   O:select substr('abcd',2,2) value from dual

  25.子串代替 返回aijklmnef
   S:SELECT STUFF('abcdef', 2, 3, 'ijklmn') value
   O:SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual

  26.子串全部替换
   S:没发现
   O:select Translate('fasdbfasegas','fa','我' ) value from dual

  27.长度
   S:len,datalength
   O:length

  28.大小写转换 lower,upper

  29.单词首字母大写
   S:没发现
   O:select INITCAP('abcd dsaf df') value from dual

  30.左补空格(LPAD的第一个参数为空格则同space函数)
   S:select space(10)+'abcd' value
   O:select LPAD('abcd',14) value from dual

  31.右补空格(RPAD的第一个参数为空格则同space函数)
   S:select 'abcd'+space(10) value
   O:select RPAD('abcd',14) value from dual

  32.删除空格
   S:ltrim,rtrim
   O:ltrim,rtrim,trim

  33. 重复字符串
   S:select REPLICATE('abcd',2) value
   O:没发现

  34.发音相似性比较(这两个单词返回值一样,发音相同)
   S:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe')
   O:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') from dual
   SQLServer中用SELECT DIFFERENCE('Smithers', 'Smythers') 比较soundex的差
   返回0-4,4为同音,1最高

日期函数
   35.系统时间
   S:select getdate() value
   O:select sysdate value from dual

  36.前后几日
   直接与整数相加减

  37.求日期
   S:select convert(char(10),getdate(),20) value
   O:select trunc(sysdate) value from dual
   select to_char(sysdate,'yyyy-mm-dd') value from dual

  38.求时间
   S:select convert(char(8),getdate(),108) value
   O:select to_char(sysdate,'hh24:mm:ss') value from dual

39.取日期时间的其他部分
   S:DATEPART 和 DATENAME 函数 (第一个参数决定)
   O:to_char函数 第二个参数决定

  参数---------------------------------下表需要补充
   year yy, yyyy
   quarter qq, q (季度)
   month mm, m (m O无效)
   dayofyear dy, y (O表星期)
   day dd, d (d O无效)
   week wk, ww (wk O无效)
   weekday dw (O不清楚)
   Hour hh,hh12,hh24 (hh12,hh24 S无效)
   minute mi, n (n O无效)
   second ss, s (s O无效)
   millisecond ms (O无效)
   ----------------------------------------------

  40.当月最后一天
   S:不知道
   O:select LAST_DAY(sysdate) value from dual

  41.本星期的某一天(比如星期日)
   S:不知道
   O:SELECT Next_day(sysdate,7) vaule FROM DUAL;

  42.字符串转时间
   S:可以直接转或者select cast('2004-09-08'as datetime) value
   O:SELECT To_date('2004-01-05 22:09:38','yyyy-mm-dd hh24-mi-ss') vaule FROM DUAL;

  43.求两日期某一部分的差(比如秒)
   S:select datediff(ss,getdate(),getdate()+12.3) value
   O:直接用两个日期相减(比如d1-d2=12.3)
   SELECT (d1-d2)*24*60*60 vaule FROM DUAL;

  44.根据差值求新的日期(比如分钟)
   S:select dateadd(mi,8,getdate()) value
   O:SELECT sysdate+8/60/24 vaule FROM DUAL;

  45.求不同时区时间
   S:不知道
   O:SELECT New_time(sysdate,'ydt','gmt' ) vaule FROM DUAL;

  -----时区参数,北京在东8区应该是Ydt-------
   AST ADT 大西洋标准时间
   BST BDT 白令海标准时间
   CST CDT 中部标准时间
   EST EDT 东部标准时间
   GMT 格林尼治标准时间
   HST HDT 阿拉斯加?夏威夷标准时间
   MST MDT 山区标准时间
   NST 纽芬兰标准时间
   PST PDT 太平洋标准时间
   YST YDT YUKON标准时间

SQLServer和Oracle的常用函数对比

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1666
14
CakePHP 教程
1425
52
Laravel 教程
1323
25
PHP教程
1272
29
C# 教程
1251
24
oracle打不開怎麼辦 oracle打不開怎麼辦 Apr 11, 2025 pm 10:06 PM

Oracle 打不開的解決辦法包括:1. 啟動數據庫服務;2. 啟動監聽器;3. 檢查端口衝突;4. 正確設置環境變量;5. 確保防火牆或防病毒軟件未阻止連接;6. 檢查服務器是否已關閉;7. 使用 RMAN 恢復損壞的文件;8. 檢查 TNS 服務名稱是否正確;9. 檢查網絡連接;10. 重新安裝 Oracle 軟件。

oracle游標關閉怎麼解決 oracle游標關閉怎麼解決 Apr 11, 2025 pm 10:18 PM

解決 Oracle 游標關閉問題的方法包括:使用 CLOSE 語句顯式關閉游標。在 FOR UPDATE 子句中聲明游標,使其在作用域結束後自動關閉。在 USING 子句中聲明游標,使其在關聯的 PL/SQL 變量關閉時自動關閉。使用異常處理確保在任何異常情況下關閉游標。使用連接池自動關閉游標。禁用自動提交,延遲游標關閉。

oracle怎麼循環創建游標 oracle怎麼循環創建游標 Apr 12, 2025 am 06:18 AM

Oracle 中,FOR LOOP 循環可動態創建游標, 步驟為:1. 定義游標類型;2. 創建循環;3. 動態創建游標;4. 執行游標;5. 關閉游標。示例:可循環創建游標,顯示前 10 名員工姓名和工資。

oracle視圖怎麼導出 oracle視圖怎麼導出 Apr 12, 2025 am 06:15 AM

可以通過 EXP 實用程序導出 Oracle 視圖:登錄 Oracle 數據庫。啟動 EXP 實用程序,指定視圖名稱和導出目錄。輸入導出參數,包括目標模式、文件格式和表空間。開始導出。使用 impdp 實用程序驗證導出。

oracle日誌寫滿怎麼辦 oracle日誌寫滿怎麼辦 Apr 12, 2025 am 06:09 AM

Oracle 日誌文件寫滿時,可採用以下解決方案:1)清理舊日誌文件;2)增加日誌文件大小;3)增加日誌文件組;4)設置自動日誌管理;5)重新初始化數據庫。在實施任何解決方案前,建議備份數據庫以防數據丟失。

HDFS配置CentOS需要哪些步驟 HDFS配置CentOS需要哪些步驟 Apr 14, 2025 pm 06:42 PM

在CentOS系統上搭建Hadoop分佈式文件系統(HDFS)需要多個步驟,本文提供一個簡要的配置指南。一、前期準備安裝JDK:在所有節點上安裝JavaDevelopmentKit(JDK),版本需與Hadoop兼容。可從Oracle官網下載安裝包。環境變量配置:編輯/etc/profile文件,設置Java和Hadoop的環境變量,使系統能夠找到JDK和Hadoop的安裝路徑。二、安全配置:SSH免密登錄生成SSH密鑰:在每個節點上使用ssh-keygen命令

甲骨文在商業世界中的作用 甲骨文在商業世界中的作用 Apr 23, 2025 am 12:01 AM

Oracle不僅是數據庫公司,還是雲計算和ERP系統的領導者。 1.Oracle提供從數據庫到雲服務和ERP系統的全面解決方案。 2.OracleCloud挑戰AWS和Azure,提供IaaS、PaaS和SaaS服務。 3.Oracle的ERP系統如E-BusinessSuite和FusionApplications幫助企業優化運營。

oracle數據庫怎麼停止 oracle數據庫怎麼停止 Apr 12, 2025 am 06:12 AM

要停止 Oracle 數據庫,請執行以下步驟:1. 連接到數據庫;2. 優雅關機數據庫(shutdown immediate);3. 完全關機數據庫(shutdown abort)。

See all articles