91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle函數-單行函數-轉換函數、條件表達式

發布時間:2020-07-09 05:41:21 來源:網絡 閱讀:507 作者:大Q小Q 欄目:關系型數據庫

Oracle函數-單行函數-轉換函數、條件表達式

單行函數

============================================================

特點:

每行返回一個結果,輸入輸出存在一一對應的關系

能嵌套使用 ,一個函數的輸出能做另外一個函數的輸入 如:select lowner(upper('aa')) from dual;

傳入的變量可以是列的值,也可以是表達式。 如 select lower(ename) from emp;


============================================================

Oracle函數-單行函數-轉換函數、條件表達式

轉換函數:

to_number: 將字符類型的數據轉換為數字類型

to_date:將字符類型的數據轉換為日期類型d

to_char:將number或者是date類型的數據轉換為字符類型


============================================================


1.1、to_char:將時間類型的數據轉換為字符類型

語法:to_char(date,'format_model')

format_model:日期格式類型

yyyy    數字年份形式 四位數

year     年份的拼寫形式

mm      數字日期形式

month 月份的全拼格式

mon     月份的簡寫  三位數

dy        星期的簡寫   三位數

day      星期的全寫

dd        數字形式日期 兩位數


例如:

①查詢當前時間,時間格式顯示為2011-01-02 12:10:13

SQL>select sysdate from dual;   ----顯示默認的時間格式

SQL>select to_char(sysdate,'yyyy-mm-dd hh34:mi:ss') from dual;


②查詢當前時間,時間格式顯示為 “星期全寫 四位年 月份全寫"

SQL>select to_char(sysdate,'day yyyy month') from dual;


③fm的使用 去掉前導0

SQL> select to_char(sysdate-13,'dd') from dual;


TO

--

07


SQL> select to_char(sysdate-13,'fmdd') from dual;


TO

--

7


④日期格式里面插入字符,需要用雙引號把字符引起來,如”  星期全寫 victor 四位年 月份全寫"

SQL>select to_char(sysdate,'day "victor" yyyy month') from dual;


============================================================


1.2、to_char:將數字類型的數據轉換為字符類型

語法:to_char(number,'format_model')

format_model:格式類型

9    ----有多少個number(就是多少位) 都真實的顯示出來,如果前面是0的,后面是number的,前面的0不顯示

0    ----有多少位就顯示多少位,不足的用0填充

$    ----用美元顯示

L    ----使用本地貨幣符號

.

,


①測試9和0的區別:想要把工資顯示為x,xxx.xx這種格式

SQL>select ename,to_char(sal,'9,999.99') from emp;

改成

SQL>select ename,to_char(sal,'9,009.09') from emp; 

發現沒有區別,因為9和0都是表示一位數字

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

改成

SQL>select ename,to_char(sal,'0,999.99') from emp; 

現在需要顯示4位數,800要顯示為0800,由于前面是0,那就是說不夠的用0填充

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

改成

SQL>select ename,to_char(sal,'09909090,999.99') from emp; 

總結:9和0都是表示一個數字,0表示不足位的時候用0去填充,一般只用在前導位。


============================================================


2、to_number:用于將字符類型轉換為數字類型

SQL>select to_number('234234.4350','999999.0000') from dual;


TO_NUMBER('RMB234234.4350','L999999.0000')

——————————————

234234.435


①用于將16進制轉化為10進制

SQL>select to_number('fa','xxxxx') from dual;


============================================================


3、to_date:用于將數據轉換為日期類型

語法:to_date('char','format_model')

format_model:格式類型

yyyy    數字年份形式 四位數

year    年份的拼寫形式

mm     數字日期形式

month 月份的全拼格式

mon     月份的簡寫   三位數

dy        星期的簡寫   三位數

day      星期的全寫

dd       數字形式日期 兩位數


①select * from emp where hiredate < to_date('1986-07-25','yyyy-mm-dd');


============================================================


4、空值函數

①NVL(expr1,expr2):對expr1進行判斷,如果expr1為空,則返回expr2,如果expr1不為空,則返回expr1本身

SQL>select ename,comm,nvl(comm,0) from emp;

注意:數據類型需要匹配,如expr1為number,那么expr2也要為number,否則會報錯


②NVL2(exp1,expr2,expr3):對expr1進行判斷,如果expr1為空,則返回expr3,如果expr1不為空,則返回expr2;

SQL>select ename,comm,nvl2(comm,1,0) from emp;


③NULLIF(expr1,expr2):如果expr1和expr2相等,則返回null,否則返回expr1

SQL> select sal,nullif(sal,3000) from emp;


============================================================


5、條件表達式

①case的語法:

case expr  when expr1 when return_expr1

                  when expr2 when return_expr2

                  when expr3 when return_expr3

                  else else_expr

end;


eg:對deptno進行判斷,如果10號部門,返回一倍工資(1*sal),如果是20號部門,返回兩倍工資(2*sal),如果是30,返回3倍工資,如果都不是,則返回一半工資

select ename,deptno,sal,

  case deptno 

    when 10 then 1*sal

    when 20 then 2*sal

    when 30 then 3*sal

    else sal/2

   end

from emp;


②decode:decode(expr1,expr2,expr3,.........)


eg:對deptno進行判斷,如果是10號部門,返回一倍工資(1*sal),如果不是,則返回0。

SQL>select ename,deptno,sal,decode(deptno,10,sal,0) from emp;


eg:對deptno進行判斷,如果是10號部門,返回一倍工資(1*sal);如果是30號部門,返回30倍工資(30*sal);如果是41號部門,返回50。

SQL>select ename,deptno,sal,decode(deptno,10,sal,30,30*sal,41,50) from emp; 


使用decode 改寫case中的列子

SQL>select ename,deptno,sal,decode(deptno,10,sal,20,2*sal,30,3*sal,sal/2) from emp; 



向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

苏尼特左旗| 广德县| 迁安市| 政和县| 咸宁市| 新民市| 西安市| 金乡县| 安阳市| 商洛市| 奇台县| 石狮市| 卫辉市| 德清县| 岑溪市| 洛川县| 成武县| 昌吉市| 固原市| 土默特左旗| 门头沟区| 府谷县| 页游| 高青县| 霍山县| 抚远县| 集贤县| 军事| 东乡| 金川县| 华容县| 佳木斯市| 时尚| 石城县| 应用必备| 景宁| 平乐县| 稷山县| 德州市| 同心县| 宁波市|