首頁 常見問題 什麼是oracle函數

什麼是oracle函數

Jun 06, 2023 am 10:15 AM
oracle 函數

oracle函數是PL/SQL子程序,作為資料庫物件儲存在oracle資料庫中,會對傳遞進來的參數進行處理,並傳回一個處理結果,也就是傳回一個值,通常用於傳回特定的數據,oracle函數可分為系統函數和使用者自訂函數兩類。

什麼是oracle函數

本教學操作環境:Windows10系統、Oracle 19c版本、Dell G3電腦。

Oracle函數的定義

函數是作為資料庫物件儲存在oracle資料庫中,函數又稱為PL/SQL子程式。

函數會對傳遞進來的參數進行處理,並傳回一個處理結果,也就是傳回一個值。通常用於傳回特定的數據。

oracle函數可分為兩類:系統函數和使用者自訂函數。

ORACLE函數之單行函數

  • 不改變真實數據,只對數據做進一步修飾或處理顯示
  • #可和欄位混合使用

    偽表:真實存在的表,方便進行資料驗證而暫時存在;表名:dual

1.字元函數

#函數名稱 作用 範例 結果
initcap(char) 首字母大寫 initcap('nice') Nice
lower(char) 轉為小寫 lower('NICE') nice
#upper(char) #轉為大寫 #upper('nice') NICE
#ltrim(char,set) 左剪 ltrim( 'nice','ni') ce
rtrim(char,set) #右剪 rtrim(' nice','e') nic
concat(char1,char2) 字串連接 concat(' ni','ce') nice
substr(char,pos,len) 取子字串 substr ('nice',2,2) ic
instr(char,substr) 查子字串位置 instr('nice','c') 3
translate(char,key,value) 依字元對映翻譯 translate('nice','ne','01') 0ic1
replace(char,old,new) #字串替換 replace('nice','c','cc') #nicce

2.數值函數

##mod( m,n)取餘mod(3,2)1##sign(n)#ceil(n)##往上取整ceil(3.2)4#floor(n)向下取整floor( 3.2)3round(m,n)四捨五入為指定小數位數round(3.236,2 )3.24power(m,n)m的n次方power(3,2)9sqrt(n)平方根sqrt(4)2trunc(m,n)截斷trunc(3.233,2)3.23sin(n)正弦sin(0)0cos(n)餘弦cos(0)1#

3.日期函數

函數名稱 作用 範例
abs(n) 取絕對值 abs(-3) 3
取符號 sign(-3) -1
#025-7月-202024-8月-2020#31-8月-20201-1月-202101-1月-2020
函數名稱 作用 範例 結果
#months_between(date1,date2) 返回兩日期間的月份(若date1在日曆中比date2早,則傳回一個負數,反之則回傳一個正數) months_between('01-8月-2020','01-8月-2020')
add_months( date,m) 返回把月份數加到日期上的新日期 add_months('25-8月-2020',-1)
next_day(date,week) 傳回指定新日期後的星期對應的新日期 next_day('23-8月-2020','星期一')
last_day(date) 傳回指定日期所在月的最後一天 last_day('25-8月-2020')
round(date,p) 依指定格式對日期進行四捨五入 round(to_date('25-8月-2020'),'YEAR')
trunc(date,p) 對日期依指定方式截斷 trunc(to_date('25-8  月-2020'),'YEAR ')

    #註:
  • p為YEAR,round按1-6月和7-12月,四捨五入到最近的yyyy年1月;trunc截取到本年第一天。
  • p為MONTH,round依1-15日及16-30日,四捨五入至最近mm月的1日;trunc截取到本月第一天。
p為DAY,round依週一至週三和週四至週日,四捨五入至最近的週日。 trunc截取到本週第一天。

oracle函數之多行函數
  • #對查詢資料進行統計

    不能和普通欄位及單行函數混合使用,除非分組作用##max(欄位名稱)傳回該欄位最大值min(欄位名稱)傳回該欄位最小值##sum(欄位名稱)傳回該欄位的和avg(欄位名稱)傳回該欄位平均值count(*)傳回表格記錄數#count(欄位名稱)傳回非空值數count(distinct 欄位名稱)返回去重後欄位值數
    函數名稱

    oracle函數之轉換函數
  • to_number(數值類型的字元):將字元轉換為數值

    to_char(數值或日期):將數值或日期轉換為字元

    指定顯示格式:

    9表示佔位,範例:999,999,999會將數字以三個一組逗號隔開。

    0表示佔位,若實際資料位數不足,則用0補位。

    L表示人民幣符號,$表示美元符號。
  • 附註:數值與字元之間可隱式轉換。

    to_date(日期格式的字元):將字元轉換為日期(一般新增使用,查詢用to_char)

    常用日期格式:yyyy-mm-dd

    yyyy/mm/dd

    'yyyy"年"mm"月"dd"日"'
註:字元必須符合日期格式;oracle預設轉換格式為日月年,例'25-8月-2020'。

    oracle函數之其他函數
  • #nvl(欄位名,新的值):若欄位值不為null,則傳回該欄位值;若為null,則傳回新的值。

  • nvl2(字段名,處理1,處理2):若字段值不為null,則執行處理1;若為null,則執行處理2。

decode(字段名,值1,處理1,值2,處理2,值3,處理3,...,公共處理):若字段值和decode中條件值相同,則執行對應的處理。若都沒有,則執行公共處理。 ##########

以上是什麼是oracle函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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 教程
1327
25
PHP教程
1273
29
C# 教程
1252
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)。