首页
/
每日頭條
/
科技
/
oracle 函數用法
oracle 函數用法
更新时间:2025-12-01 07:03:18
在oracle數據庫中,函數有聚合函數、單行函數、開窗函數等等,其中在sql語句編輯計算過程中,單行函數的使用頻率又尤為突出。

所以今天我們一起來看看單行函數在oracle中有哪些是比較常見常用的。

一、數字類型

進行數字絕對值的求值:abs()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)1

例如,查看emp表裡面,有設置獎金的員工裡面,獎金和工資之間的絕對值差距是多少?

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)2

對數字進行四舍五入:round(n, 保留的小數精度)

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)3

對數字進行截取:trunc(n, 保留的小數精度)

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)4

進行數字的向上取整:ceil() 找比自己大的最近的這個整數

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)5

進行數字的向下取整:floor() 找比自己小的最近的這個整數

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)6

進行數字的幂運算:power(n, 次方) 數字的多少次方

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)7

進行數字的取餘數運算:mod(被除數, 除數) 除法運算的餘數,經常用來判斷倍數關系

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)8

二、字符串類型

進行字符串的截取:substr()

1. substr(s, 開始序号, 連續長度)

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)9

查詢首字母是A開頭的員工名字

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)10

查詢倒數第二個字母是E的員工名字

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)11

2. substr(s, 開始序号) 沒有連續的長度,默認就是從開始一直取到最後一個

查詢名字的最後三個字母是 NES 的員工名字

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)12

字符串的拼接:concat(s1, s2) concat()函數隻能拼接兩個内容

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)13

如果要在兩個内容中間,需要加上符号,用三個内容拼接起來一個字符串,那麼就需要使用concat()函數的嵌套了。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)14

在oracle裡面,拼接一般使用 || 進行。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)15

查詢字符串的長度:length()

查詢名字的長度剛好是5個字母的員工信息

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)16

将字符串轉換成小寫:lower()

将字符串轉換成大寫:upper()

将字符串轉換成首字母大寫其他字母小寫:initcap()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)17

使用上面學過的函數,嵌套一個新的功能出來,查詢員工的名字,最後一個字母大寫,其他字母小寫。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)18

在一個大的字符串裡面,查找是否有包含另一個字符或者字符串,返回找到的字符在大的字符串中的位置:instr()

1. instr(s, '查找的内容')

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)19

隻會返回遇到的第一個匹配值,如果沒有匹配,就返回0。

2. instr(s, '查找的内容', 從第幾個序号開始查找, 找第幾個匹配的内容)

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)20

3. 我們放到一個筆試題裡面看看 instr() 函數的使用:

下面的表格,每一行都由省-市-區組成,現在我們需要取出每行中間城市的名稱。

create table addrs(

addr varchar2(50)

);

insert into addrs values('廣東省-深圳市-羅湖區');

insert into addrs values('新疆維吾爾自治區-伊犁市-烏魯木齊');

insert into addrs values('湖南省-長沙市-天心區');

commit;

我們使用instr()查找第一個和第二個分隔符的位置,再使用substr()進行截取就好了。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)21

字符串的替換方法:replace(s, '舊字符', '新字符')

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)22

取出名字裡面所有的A

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)23

删除某個指定範圍的數據:translate(s, '要被替換的很多個舊字符' , ' ')

例如下面這個題目,我們有很多個用戶名username,我們需要找出包含了數字的有哪些。

create table user_inf2(

userid number,

username varchar2(50)

);

insert into user_inf2 values(1,'ieiuefjdkk');

insert into user_inf2 values(2,'ifjsk13234');

insert into user_inf2 values(3,'5634kjdfkl12');

insert into user_inf2 values(4,'9883475');

insert into user_inf2 values(5,'872176lkgkj');

我們将數字都去掉,然後查看和原字符串不相同的數據即可。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)24

正則表達式的數據替換方法:regexp_replace(s, '正則表達式', '新的内容')

這個用正則的替換方法同樣可以實現。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)25

舉一個正則表達式的例子:

我們要删除下面這個表格中,所有城市名字前面的數字序号。

create table user_inf3(

userid number,

addr varchar2(100)

);

insert into user_inf3 values(1,'1:深圳,2:廣州');

insert into user_inf3 values(2,'1:北京,2:上海,3:杭州');

insert into user_inf3 values(3,'1:武漢,2:武漢2');

數字範圍[0-9]也可以使用 \d 進行替換。

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)26

三、時間日期類型

獲取當前的時間日期:sysdate current_date

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)27

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)28

獲取查看日期所在的月份的最後一天:last_day()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)29

查看日期之間的月份間隔:months_between()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)30

月份的偏移查詢:add_months() 在這個日期的基礎上,往前或者往後移動N個月

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)31

日期天數的間隔計算,直接用 減法 :

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)32

進行日期天數的偏移查詢:

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)33

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)34

日期 數字截取的函數 trunc() ,實現日期的截斷:

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)35

日期截取的維度:

yyyy 年

mm 月

dd 天

hh24 小時

mi 分鐘

day 周

一個實際的練習:

顯示一個永遠是明天早上十點的時間:

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)36

四、數據類型轉換

将一個純數字組成的字符串轉換成數字類型:to_number()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)37

将一個數字類型或者日期類型轉換成字符串類型:to_char()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)38

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)39

将時間日期格式的字符串 轉換成日期類型:to_date()

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)40

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)41

時間提取的維度有:

yyyy 年

mm 月

dd 日

hh24 時

mi 分

ss 秒

day 周

練習:

查詢emp表中,每一年分别有多少員工入職?

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)42

查詢emp表中,每個員工入職了多少年零多少月?

oracle 函數用法(ORACLE數據庫中常見的單行函數的使用和操作)43

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
微信安裝包解析異常是什麼問題
微信安裝包解析異常是什麼問題
1、用戶下載的apk程序本身就有問題,程序的壓縮包可能在下載過程中被損壞了。用戶的手機的配置參數不支持這款軟件。2、RE文件管理設置的緣故,如果将其設置成【sdcard】就會出現【解析包出現問題】的錯誤提示,您可以重新下載安裝apk程序,并且在RE文件管理器中設置為【】即可。3、如果重新下載也解決不了Android解析包出現問題的話,很大一個可能就是在于你的手機的配置參數不支持這款軟件;比如說您的
2025-12-01
加盟母嬰店怎麼做
加盟母嬰店怎麼做
第一、有調研才有發言權。你想開母嬰店的話,首先要考慮市場是不是飽和了,如果沒有飽和的話,是要走高端路線,還是要走中低端路線,這些都是要考慮的,因為母嬰店的選址、當地的消費情況等,都跟你未來要選擇的母嬰品牌加盟店有關。第二、選擇合适品牌。每一家母嬰加盟店的定位都是不一樣的,而且品牌的影響力也不同,另外還有一點要考慮的是品牌加盟費也會有差距。所以你在選擇加盟某品牌母嬰店的時候,就要考慮到這一點。第三、
2025-12-01
如何給bios設置密碼
如何給bios設置密碼
1、打開電腦,在開機信息出現時按下Del”鍵根據個人電腦型号而定)就進入BIOS設置。2、在bios菜單中可以看到SetSupervisorPassword”設置超級用戶密碼)與SetUserPassword”設置用戶密碼)兩個密碼選項。3、選擇其中一個按下回車鍵,然後在對話框中輸入密碼。輸入完畢後按下回車鍵。4、這是系統會提示确認密碼。再一次輸入剛才的密碼即可。5、回到主菜單中,選擇Advanc
2025-12-01
經典福克斯離合器太高了怎麼調低
經典福克斯離合器太高了怎麼調低
1、熄火,拉手刹,空檔。2、人趴在駕駛員腳下的位置,找點軟的東西墊一下,很痛苦的。3、拆掉那個帶燈的一塊塑料闆,拆時有技巧,用力向車頭方向推,然後反方向的會跟車身脫離,向下一拉,就可以了,小心拉的力度,小心拉斷那裡面有個調情燈的燈線。4、然後找個開口扳手,逆時針擰松,然後就可以用調高低了,順時針是調低,逆時針是調高。5、來回自己試一下車。感覺不錯了,就算調好後,順時針闆手固定好螺絲。6、将那塊塑料
2025-12-01
聯通信号出現hd是什麼
聯通信号出現hd是什麼
1、移動、聯通、電信三大運營商android安卓)手機、移動運營商的iphone蘋果)手機的信号欄裡會突然顯示HD”這兩個英文字母标識,那是因為你的手機卡已開通三大運營商的VoLTE通話業務導緻的。2、VoLTE是運營商推出的4G高清語音/視頻通訊業務,全稱為VoiceoverLTE”,是基于IMS的語音業務。它是一種IP數據傳輸技術,無需2G/3G網,全部業務承載于4G網絡上,可實現數據與語音業
2025-12-01
Copyright 2023-2025 - www.tftnews.com All Rights Reserved