05.單行函數(shù)與多行函數(shù)【聚合函數(shù)】

單行函數(shù)與多行函數(shù)【聚合函數(shù)】

以下演示將在scott用戶下進(jìn)行dual 表示虛表办铡,為了填充語法辞做,沒有實(shí)際意義

單行函數(shù):作用于一行琳要,返回一個(gè)值

一、字符函數(shù)【單行函數(shù)】

select upper('upper') from dual; -- 變大寫
select lower('LOWER') from dual; -- 變小寫

練習(xí):根據(jù) API 學(xué)習(xí):首字母大寫函數(shù)秤茅、字符串鏈接函數(shù)稚补、字符串截取函數(shù)、字符串替換函數(shù)框喳、獲取字符串長(zhǎng)度函數(shù)等课幕。

二、數(shù)值函數(shù)【單行函數(shù)】

-- 四舍五入五垮,第二個(gè)參數(shù)表示保留的位數(shù)乍惊,
-- 正整數(shù)就向小數(shù)點(diǎn)后保留,負(fù)整數(shù)就向小數(shù)點(diǎn)前前保留;
-- 不寫第二個(gè)參數(shù)默認(rèn)保留0位小數(shù)
select round(56.16, 1) from dual;

-- 直接截取放仗,與round類似润绎,只是不再四舍五入
select trunc(56.16, -2) from dual;

 -- 求余數(shù)
select mod(10, 3) from dual;

練習(xí):根據(jù) API 學(xué)習(xí):數(shù)值截取函數(shù)、取余函數(shù)等

三诞挨、日期函數(shù)【單行函數(shù)】

sysdate 表示當(dāng)前系統(tǒng)時(shí)間

1). 日期函數(shù)的運(yùn)算

  1. 日期 – 數(shù)字 = 日期
  2. 日期 + 數(shù)字 = 日期
  3. 日期 – 日期 = 數(shù)字

2). 案例演示

--- 查詢出emp表中所有員工入職距離現(xiàn)在有多少天
select sysdate - e.hiredate from emp e;

--- 算出明天此刻
select sysdate + 1 from dual;

--- 查詢出emp表中所有員工入職距離現(xiàn)在幾個(gè)月,【只有月有這個(gè)函數(shù)】
select months_between(sysdate, e.hiredate) from emp e;

--- 查詢出emp表中所有員工入職距離現(xiàn)在幾年
select months_between(sysdate, e.hiredate)/12 from emp e;

--- 查詢出emp表中所有員工入職距離現(xiàn)在幾周,四舍五入
select round((sysdate-e.hiredate)/7) from emp e;

四凡橱、轉(zhuǎn)換函數(shù)【單行函數(shù)】

對(duì)日期的轉(zhuǎn)換 匹配格式不區(qū)分大小寫

1). to_char: 將日期轉(zhuǎn)換為字符串

-- 將當(dāng)前日期轉(zhuǎn)換成字符串
select to_char(sysdate, 'yyyy-mm-dd hh:mi:ss') from dual;

-- fm 取消自動(dòng)補(bǔ)0
select to_char(sysdate, 'fm yyyy-mm-dd hh:mi:ss') from dual;

-- 24小時(shí)計(jì)數(shù)法
select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual;

-- 查詢所有的雇員將將年月日分開
select
       empno,
       ename,
       to_char(hiredate, 'yyyy') 年,
       to_char(hiredate, 'mm') 月,
       to_char(hiredate, 'dd') 日
from emp;

2). to_date:將字符串轉(zhuǎn)換為日期類型

模式得對(duì)應(yīng)匹配,比如 fm 24小時(shí)制

-- 將字符串轉(zhuǎn)換成日期
select to_date('2019-02-09 16:23:50', 'yyyy-mm-dd hh24:mi:ss') from dual;

五亭姥、通用函數(shù)【單行函數(shù)稼钩,常用】

通用,MySQL等關(guān)系型數(shù)據(jù)庫中也可以使用

1). 空值null處理nvl

使用 nvl(notNullChoiceMe, ifNullChoiceMe) 進(jìn)行判斷达罗,第一個(gè)參數(shù)是需要查詢的值坝撑,如果是null,則使用第二個(gè)參數(shù)粮揉,否則使用本身

select e.sal * 12 + nvl(e.comm, 0) from emp e;

2). case when: 條件表達(dá)式

1. 語法

CASE expr WHEN comparison_expr1 THEN return_expr1
[WHEN comparison_expr2 THEN return_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END

2. 案例

  1. 等值判斷】為查詢結(jié)果取別名
select e.ename,
       case e.ename
         when 'SMITH' then '史密斯'
           when 'ALLEN' then '愛麗絲'
             when 'WARD' then '守衛(wèi)'
               else '無名之輩'
                 end
from emp e;
  1. 范圍判斷】判斷emp表中員工工資巡李,如果高于3000顯示高收入,如果咋1500~3000顯示中等扶认,其余顯示低收入侨拦。
select e.ename, e.sal,
       case
         when e.sal > 3000 then '高收入'
           when e.sal > 1500 and e.sal < 3000 then '中等收入'
               else '低收入'
                 end
from emp e;

3). decode函數(shù)【Oracle方言,了解】

該函數(shù)類型于if...else if...else辐宾;不建議使用

1. 語法

DECODE(col/expression, [search1,result1],[search2, result2]....[default])
  • 參數(shù)介紹
    • Col/expression: 列名或表達(dá)式
    • Search1狱从,search2...: 用于比較的條件
    • Result1, result2...: 返回值
    • 如果col/expression 和 Searchi匹配就返回resulti,否則返回default的默認(rèn)值

2. 使用案例

select decode(0, 0, '我是0', 1, '我是1', '我是!0&&!1') resu from dual;
-- 查詢出所有雇員的職位中文名
select
     ename,
     decode( job,
          'CLERK', '業(yè)務(wù)員',
          'SALESMAN', '銷售',
          'PRESIDENT', '總裁',
          'MANAGER','經(jīng)理',
          'nothing'
     )
from
       emp;

六、多行函數(shù)

5個(gè)聚合函數(shù)

-- 查詢總數(shù)量叠纹, count(1)等同于count(主鍵)季研,count(*)
-- 不建議使用count(*),應(yīng)為影響性能
select count(1) from emp;

select sum(sal) from emp; -- 總和

select max(sal) from emp; -- 最大值

select min(sal) from emp; -- 最小值

select avg(sal) from emp; -- 平均值
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末誉察,一起剝皮案震驚了整個(gè)濱河市与涡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖驼卖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件氨肌,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡酌畜,警方通過查閱死者的電腦和手機(jī)儒飒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來檩奠,“玉大人桩了,你說我怎么就攤上這事〔捍粒” “怎么了井誉?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)整胃。 經(jīng)常有香客問我颗圣,道長(zhǎng),這世上最難降的妖魔是什么屁使? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任在岂,我火速辦了婚禮,結(jié)果婚禮上蛮寂,老公的妹妹穿的比我還像新娘蔽午。我一直安慰自己,他們只是感情好酬蹋,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布及老。 她就那樣靜靜地躺著,像睡著了一般范抓。 火紅的嫁衣襯著肌膚如雪骄恶。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼并扇。 笑死,一個(gè)胖子當(dāng)著我的面吹牛寞秃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播单芜,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼蜕该,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了洲鸠?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎扒腕,沒想到半個(gè)月后绢淀,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瘾腰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年皆的,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蹋盆。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡费薄,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出栖雾,到底是詐尸還是另有隱情楞抡,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布析藕,位于F島的核電站召廷,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏账胧。R本人自食惡果不足惜竞慢,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望治泥。 院中可真熱鬧筹煮,春花似錦、人聲如沸居夹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吮播。三九已至变屁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間意狠,已是汗流浹背粟关。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留环戈,地道東北人闷板。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像院塞,于是被迫代替她去往敵國(guó)和親遮晚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Hive函數(shù) Hive函數(shù) 一拦止、關(guān)系運(yùn)算: 等值比較: = 語法:A=B操作類型:所有基本類型描述:如果表達(dá)式A與...
    依天立業(yè)閱讀 825評(píng)論 0 8
  • 第5章 引用類型(返回首頁) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,216評(píng)論 0 4
  • ??引用類型的值(對(duì)象)是引用類型的一個(gè)實(shí)例。 ??在 ECMAscript 中萧求,引用類型是一種數(shù)據(jù)結(jié)構(gòu)其兴,用于將數(shù)...
    霜天曉閱讀 1,042評(píng)論 0 1
  • 最近在寫一個(gè)IOS 緩存功能時(shí)候,當(dāng)寫到diskCache時(shí)候夸政,本人參考了YYDiskCache,使用了NSKey...
    object_boy閱讀 620評(píng)論 0 1
  • 手機(jī)下載了一個(gè)APP叫形色元旬,是一款拍照上傳就能識(shí)別花名的軟件。今天帶睿爺在小區(qū)遛達(dá)發(fā)現(xiàn)好多花都開了守问,而且都叫...
    白水啊白水閱讀 113評(píng)論 0 0