千家信息网

Oracle专题5之Oracle的单行函数

发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,SQL函数是什么?SQL函数是Oracle数据库的内置函数,并且可用于各种SQL语句。SQL函数包含单行函数和多行函数。1、字符函数字符函数的输入为字符类型,其返回值是字符类型或者是数字类型。字符函数
千家信息网最后更新 2025年01月21日Oracle专题5之Oracle的单行函数
  • SQL函数是什么?SQL函数是Oracle数据库的内置函数,并且可用于各种SQL语句。SQL函数包含单行函数和多行函数。

    1、字符函数

  • 字符函数的输入为字符类型,其返回值是字符类型或者是数字类型。
  • 字符函数可以分为大小写控制函数(UPPER、LOWER和INITCAP)和字符控制函数(CONCAT、SUBSTR、LENGTH、INSERT、LPAD、RPAD、TRIM、REPLACE)两类。

    a、大小写控制函数

  • 这类函数用于改变字符的大小写。(需要注意的是,当输入的字符为NULL(null)时,返回值也为NULL)
  • UPPER(char):该函数用于将字符串转换成大写格式。
  • LOWER(char):该函数用于将字符串转换成小写格式。
  • INITCAP(char):该函数用于将字符串中的每个单词的首字母大写,其他字符小写。
  • 示例:
    SQL> conn scott/02000059已连接。SQL> select * from emp where job = upper('salesman');         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300                30            7521 WARD       SALESMAN        7698 22-2月 -81           1250        500                30            7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400                30         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0                30
    SQL> select * from emp where lower(job) = 'clerk';         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7369 G_EASON    CLERK           7902 17-12月-80            800                20            7876 ADAMS      CLERK           7788 23-5月 -87           1100                20            7900 JAMES      CLERK           7698 03-12月-81            950                30         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7934 MILLER     CLERK           7782 23-1月 -82           1300                10
    SQL> select empno, initcap(ename) ename from emp;         EMPNO ENAME            7369 G_Eason            7499 Allen            7521 Ward            7566 Jones            7654 Martin            7698 Blake            7782 Clark            7788 Scott            7839 King            7844 Turner            7876 Adams         EMPNO ENAME            7900 James            7902 Ford            7934 Miller已选择14行。

    b、字符控制函数

  • CONCAT(str1, str2):该函数用于字符串的连接,str1和str2用于指定被连接的字符串。
  • 例如:concat('lello', 'oracle') 结果:hellooracle
    SQL> select concat(concat(ename, ':'),sal) from emp;CONCAT(CONCAT(ENAME,':'),SAL)G_EASON:800ALLEN:1600WARD:1250JONES:2975MARTIN:1250BLAKE:2850CLARK:2450SCOTT:3000KING:5000TURNER:1500ADAMS:1100JAMES:950FORD:3000MILLER:1300已选择14行。

  • SUBSTR(char, m[,n]):该函数用于截取字符串,char指定源自符串,m用于指定从哪个位置开始截取,n用于指定截取字符串的长度。如果m为0,则从首字母开始,如果m为负数,则从尾部开始。
  • 例如:substr('hello'1,3),结果为:ell;substr('hello',0,3),结果为hel;substr('hello',-1,1),结果为:o。
    SQL> select * from emp where substr(job, 1, 4) = 'SALE';         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300                30            7521 WARD       SALESMAN        7698 22-2月 -81           1250        500                30            7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400                30         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0                30

  • LENGTH(char):该函数用于返回字符串的长度,字符串中的后缀空格也计作字符串的长度。例如length('oracle '),结果为:7。
    SQL> select * from emp where length(ename) = 6;         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400                30            7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0                30            7934 MILLER     CLERK           7782 23-1月 -82           1300                10

  • INSTR(char1, char2, [,n[,m]]):该函数用于取得子串在字符串中的位置,char1用于指定源字符串,char2用于指定子串,n用于指定起始搜索位置(默认值:1),m用于指定子串的第m次出现的次数(默认值:1)。
  • 例如:instr('hello oracle', 'oracle'),结果为:7;instr('hello oracle hello oracle', 'oracle', 1, 2),结果为:20。
    SQL> select instr('hello oracle', 'oracle') from dual;INSTR('HELLOORACLE','ORACLE')                        7
    SQL> select instr('hello oracle hello oracle', 'oracle', 5, 2) from dual;INSTR('HELLOORACLEHELLOORACLE','ORACLE',5,2)                                                                                    20
  • 注意,dual为一张虚拟的表。

  • LPAD(char1, n char2):该函数用于在字符串的左端填充字符,char1用于指定源字符串,char2用于指定被填充的字符,n用于指定填充后的char1的总长度。
  • 例如:lpad('hello',10,'#'),结果是:#####hello。
        SQL> select lpad(job , 9, '*') from emp;    LPAD(JOB,9,'*')    ****CLERK    *SALESMAN    *SALESMAN    **MANAGER    *SALESMAN    **MANAGER    **MANAGER    **ANALYST    PRESIDENT    *SALESMAN    ****CLERK    ****CLERK    **ANALYST    ****CLERK    已选择14行。

  • RPAD(char1, n char2):该函数用于在字符串的右端填充字符,char1用于指定源字符串,char2用于指定被填充的字符,n用于指定填充后的char1的总长度。
  • 例如:rpad('hello',10,'#'),结果是:hello#####。

  • REPLACE(char, search_string[, replacement_string]):该函数用于替换字符串的子串内容。Char用于指定源字符串,search_string用于指定被替换子串,repalcement_string用于指定替换子串。
  • 例如:replace('hello oracle', 'oracle', 'world'),结果为:hello world。
    SQL> select replace('hello oracle', 'oracle', 'world') replace_fun from dual;REPLACE_FUNhello world

    2、数值函数

  • 数值函数的输入参数和返回值都是数字类型。
  • 常用的数值函数有:ROUND(),TRUNC(),MOD()。

  • ROUND(n,[,m]):四舍五入,说明:该函数用于返回四舍五入的结果,其中n可以使任意数字,m必须是整数。
  • 例如:ROUND(25.328),结果为:25;ROUND(25.328, 2),结果为:25.33;ROUND(25.328, -1),结果为:30。
    SQL> select sal/30, round(sal/30, 2) from emp;SAL/30 ROUND(SAL/30,2)26.6666667           26.6753.3333333           53.3341.6666667           41.6799.1666667           99.1741.6666667           41.67    95              9581.6666667           81.67   100             100166.666667          166.67    50              5036.6666667           36.6731.6666667           31.67   100             10043.3333333           43.33已选择14行。

  • TRANC:截取数字,TRUNC(n, [m]),该函数用于截取数字,其中n可以是任意数字,m必须是整数。
  • 例如:trunc(25,328),结果为:25;trunc(25.328, 2),结果为:25.32;trunc(25.328, -1),结果为:20。
    SQL> select sal/30, trunc(sal/30, 2) from emp;        SAL/30 TRUNC(SAL/30,2)26.6666667           26.6653.3333333           53.3341.6666667           41.6699.1666667           99.1641.6666667           41.66                95              9581.6666667           81.66             100             100166.666667          166.66                50              5036.6666667           36.6631.6666667           31.66             100             10043.3333333           43.33已选择14行。

  • MOD:求模(求余数),MOD(m, n),该函数用于取得两个数字相除后的余数。如果数字n为0,则返回结果为m。
  • 例如:mod(25,6),结果为:1;mod(25, 0),结果为:25。
    SQL> select * from emp where mod(empno, 2) = 0;         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7566 JONES      MANAGER         7839 02-4月 -81           2975                20            7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400                30            7698 BLAKE      MANAGER         7839 01-5月 -81           2850                30            7782 CLARK      MANAGER         7839 09-6月 -81           2450                10            7788 SCOTT      ANALYST         7566 19-4月 -87           3000                20            7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0                30        DEPTNO            7876 ADAMS      CLERK           7788 23-5月 -87           1100                20            7900 JAMES      CLERK           7698 03-12月-81            950                30            7902 FORD       ANALYST         7566 03-12月-81           3000                20            7934 MILLER     CLERK           7782 23-1月 -82           1300                10已选择10行。

    3、日期和时间函数

    • 用于处理日期时间类型的函数。
    • 其常用的日期时间函数有:SYSDATE、MONTHS_BETWEEN、ADD_MONTHS、NEXT_DAY、LAST_DAY、ROUND、TRUNC。

-  SYSDATE:该函数用于返回当前系统日期。-  举例:select sysdate-1 昨天, sysdate 今天,sysdate + 1明天 from dual;。
    SQL> select sysdate-1 昨天, sysdate 今天, sysdate + 1 明天 from dual;    昨天           今天           明天    02-12月-17     03-12月-17     04-12月-17

  • MONTHS_BETWEEN(d1, d2):改函数用于返回日期d1和d2之间相差的月数。d1大于d2结果为正数,否则为负数。
  • 举例:计算员工入职多长时间,select months_between(sysdate, hiredate) from emp;。
    SQL> select round(months_between(sysdate, hiredate)/12) hiredate_year from emp;HIREDATE_YEAR                     37                     37                     37                     37                     36                     37                     36                     31                     36                     36                     31                     36                     36                     36已选择14行。

  • ADD_MONTHS:add_months(d, n)该函数用于返回特定日期时间之后或者之前的月份所对应的日期时间。(求出若干月之后的日期)d用于指定日期时间,n可以是任意整数。
  • 举例:查询每位员工入职30年后的年份,select ename, add_months(hiredate, 30* 12) from emp;。
    SQL> select ename, add_months(hiredate, 30* 12) from emp;ENAME      ADD_MONTHS(HIRG_EASON    17-12月-10ALLEN      20-2月 -11WARD       22-2月 -11JONES      02-4月 -11MARTIN     28-9月 -11BLAKE      01-5月 -11CLARK      09-6月 -11SCOTT      19-4月 -17KING       17-11月-11TURNER     08-9月 -11ADAMS      23-5月 -17JAMES      03-12月-11FORD       03-12月-11MILLER     23-1月 -12已选择14行。

  • NEXT_DAY(d,char):该函数用于返回特定日期之后的第一个工作日所对应的日期。d用于指定日期时间值,char用于指定工作日。
  • 注意:当使用该函数时,工作日必须与日期语言匹配,假如日期语言为AMERICAN,那么周一对应于MONDAY;假如日期语言为简体中文,那么周一对应于"星期一"。
  • 例如:查询周一的日期,select sysdate, nextday(sysdate, '星期一') from dual;。
    SQL> select sysdate, next_day(sysdate, '星期一') 下一个工作日 from dual;SYSDATE        下一个工作日03-12月-17     04-12月-17

  • LAST_DAY:该函数用于返回特定日期所在月份的最后一天。
  • 例如:select sysdate, last_day(sysdate) from dual;。
    SQL> select sysdate, last_day(sysdate) from dual;SYSDATE        LAST_DAY(SYSDA03-12月-17     31-12月-17

  • ROUND(d[, fmt]):该函数用于返回日期时间的四舍五入的结果。d用于指定日期的时间值,fmt用于指定四舍五入的方式。
  • 如果设置fmt为YEAR,则7月1日为分界线,如果设置fmt为MONTH,则16日为分界线。
  • 例如:如果系统时间是"20-7月-17",round(sysdate,'YEAR'),结果为:01-1月-18;round(sysdate, 'MONTH'),结果为:01-8月-17。
    SQL> select round(sysdate, 'YEAR') as 时间的四舍五入 from dual;时间的四舍五入01-1月 -18SQL> select round(sysdate, 'MONTH') as 时间的四舍五入 from dual;时间的四舍五入01-12月-17
  • 当前的系统时间为03-12月-17。

  • TRUNC:TRUNC(d[, fmt]):该函数用于截断日期时间数据。D用于指定日期的时间值,fmt用于指定截断日期时间数据的方法,如果设置fmt为YEAR,则结果为本年度的1月1日,如果设置fmt为MONTH,则结果为本月的1日。
  • 例如:trunc(sysdate, 'YEAR');trunc(sysdate, 'MONTH');。
    SQL> select trunc(sysdate, 'MONTH') as 截断的时间 from dual;截断的时间01-12月-17SQL> select trunc(sysdate, 'YEAR') as 截断的时间 from dual;截断的时间01-1月 -17
  • 当前的系统时间为03-12月-17。

    4、转换函数

  • 该函数用于将数据从一种数据类型转换成另外一种数据类型。

    a、隐式数据类型转换

  • Oracle可以隐式的(自动的)进行数据类型转换
源数据类型目标数据类型
VARCHAR2或者CHARNUMBER
VARCHAR2或者CHARDATE
NUMBERVARCHAR2
DATEVARCHAR2
  • 如下示例:

    SQL> select * from emp where sal > '3000';         EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM        DEPTNO            7839 KING       PRESIDENT            17-11月-81           5000                10
    SQL> select * from emp where hiredate = '17-11月-81'; EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMMDEPTNO  7839 KING       PRESIDENT            17-11月-81           5000    10

    b、显式地数据类型转换

  • 日期类型 -> 字符类型(使用TO_CHAR())、字符类型 -> 日期类型(使用TO_DATE())。
  • 字符类型 -> 数值类型(使用TO_NUMBER())、数值类型 -> 字符类型(使用TO_CHAR())。

  • TO_CHAR:将日期类型转换为字符类型。函数格式为:TO_CHAR(d, [, fmt [, 'nlsparams']])。
  • d用于知道你跟日起值,fmt用于指定日期格式模型,'nlsparams'用于指定日期显示语言(格式:'NLS_DATE_LANGUAGE=language')
  • 默认日期显示格式为DD-MON-RR。select to_char(hiredate, 'DD-MON-RR', 'NLS_DATE_LANGUAGE=AMERICAN') from emp;。
    SQL> select to_char(hiredate, 'DD-MON-RR', 'NLS_DATE_LANGUAGE=AMERICAN') to_char from emp;TO_CHAR17-DEC-8020-FEB-8122-FEB-8102-APR-8128-SEP-8101-MAY-8109-JUN-8119-APR-8717-NOV-8108-SEP-8123-MAY-8703-DEC-8103-DEC-8123-JAN-82已选择14行。
  • 需要注意,当在格式模型中增加字符值时,必须用双引号引住字符值。如:select to_char(hiredate, 'YYYY"年"MM"月"DD"日"') to_char from emp;。
    SQL> select to_char(hiredate, 'YYYY"年"MM"月"DD"日"') to_char from emp;TO_CHAR1980年12月17日1981年02月20日1981年02月22日1981年04月02日1981年09月28日1981年05月01日1981年06月09日1987年04月19日1981年11月17日1981年09月08日1987年05月23日1981年12月03日1981年12月03日1982年01月23日已选择14行。

  • TO_CHAR:将数值类型转换成字符类型。函数格式为:TO_CHAR(n[, fmt])。
  • n用于指定数值,fmt用于指定数字格式的模型。
  • 格式模型,常用的元素如下:
常用元素说明
9显示数字,并且会忽略前导0
0显示数字,如果位数不足,则用0补齐
.在指定位置显示小数点
,在指定位置显示逗号
$在数字前加上美元符号
L在数字前加上本地货币符号
SQL> SELECT sal, to_char(sal, 'L00,000,000.00') to_char FROM emp;       SAL           TO_CHAR       800           ¥00,000,800.00      1600          ¥00,001,600.00      1250          ¥00,001,250.00      2975          ¥00,002,975.00      1250          ¥00,001,250.00      2850          ¥00,002,850.00      2450          ¥00,002,450.00      3000          ¥00,003,000.00      5000          ¥00,005,000.00      1500          ¥00,001,500.00      1100          ¥00,001,100.00       950          ¥00,000,950.00      3000          ¥00,003,000.00      1300          ¥00,001,300.00已选择14行。SQL> SELECT sal, to_char(sal, 'L99,999,999.99')  to_char FROM emp;       SAL                 TO_CHAR       800                 ¥800.00      1600               ¥1,600.00      1250               ¥1,250.00      2975               ¥2,975.00      1250               ¥1,250.00      2850               ¥2,850.00      2450               ¥2,450.00      3000               ¥3,000.00      5000               ¥5,000.00      1500               ¥1,500.00      1100               ¥1,100.00       950                 ¥950.00      3000               ¥3,000.00      1300               ¥1,300.00已选择14行。

  • TO_DATE(char[, fmt[, 'nlsparams']]):该函数用于将字符串转换成日期类型的数据。char用于匹配日期类型的字符串,fmt用于指定日期格式模型,'nlsparams'用于指定日期语言。
  • 举例:查看1982之后入职的员工信息:select ename, hiredate from emp where hiredate > to_date('1981-12-31', 'YYYY-MM-DD');
    SQL> select ename, hiredate from emp where hiredate > to_date('1981-12-31', 'YYYY-MM-DD');ENAME      HIREDATESCOTT      19-4月 -87ADAMS      23-5月 -87MILLER     23-1月 -82

  • TO_NUMBER(n[, fmt]):该函数可以将包含数字的字符串转换成数值类型。n是包含数字的字符串,fmt用于指定数字格式模型。
  • 显示工资大于3000的所有员工的姓名和工资:
  • select ename, sal from emp where sal > to_number('¥3000', 'L99999');
    SQL> select ename, sal from emp where sal > to_number('¥3000', 'L99999');ENAME             SALKING             5000

    5、通用函数

  • 此类函数适用于任何数据类型,同时也适用于空值。如:NVL(expr1, expr2)、NVL2(expr1, expr2, expr3)、NULLIF(expr1, expr2)、COALESCE(expr1 [ , expr2 ] [, ... ])。

    处理NULL

  • 例如:select ename, sal, comm, sal + comm from emp;
  • 在Oracle9i之前,处理null只能使用函数NVL。
  • 但是从Oracle9i之后,NVL或者NVL2都可以处理NULL。

  • NVL(expr1, expr2):该函数用于处理NULL。如果expr是null,则返回expr2,如果expr1不是null,则返回expr1。
  • 例如:select ename, sal, comm, sal + nvl(comm, 0) from emp;
    SQL> select ename, sal, comm, sal + nvl(comm, 0) from emp;ENAME             SAL       COMM SAL+NVL(COMM,0)G_EASON           800                        800ALLEN            1600        300            1900WARD             1250        500            1750JONES            2975                       2975MARTIN           1250       1400            2650BLAKE            2850                       2850CLARK            2450                       2450SCOTT            3000                       3000KING             5000                       5000TURNER           1500          0            1500ADAMS            1100                       1100JAMES             950                        950FORD             3000                       3000MILLER           1300                       1300已选择14行。

  • NVL2(expr1, expr2, expr3):该函数用于处理NULL,如果expr1不是null,则返回expr2,如果expr1是null,则返回expr3。例如:select ename, sal, comm, nvl2(comm, sal+ comm, sal) nvl2 from emp;。
        SQL> select ename, sal, comm, nvl2(comm, sal+ comm, sal)  nvl2 from emp;    ENAME             SAL       COMM       NVL2    G_EASON        800                            800    ALLEN            1600          300          1900    WARD             1250        500            1750    JONES            2975                           2975    MARTIN           1250       1400           2650    BLAKE            2850                           2850    CLARK            2450                           2450    SCOTT            3000                           3000    KING                5000                           5000    TURNER           1500          0            1500    ADAMS            1100                         1100    JAMES             950                           950    FORD               3000                        3000    MILLER            1300                         1300    已选择14行。

  • NULLIF(expr1, expr2):该函数用于比较表达式expr1和expr2,如果二者相等,则返回NULL,否则返回expr1。

  • COALESCE:COALESCE(expr1[, expr2][,...]。该函数用于返回表达式列表中第一个NOT NULL表达式的结果。例如:select ename, sal, comm, coalesce(sal + comm, sal) coalesce from emp;
    SQL> select ename, sal, comm, coalesce(sal + comm, sal)  coalesce from emp;ENAME             SAL       COMM   COALESCEEASON            3000                             3000G_EASON         800                             800ALLEN            1600          300             1900WARD             1250          500            1750JONES            2975                             2975MARTIN           1250         1400           2650BLAKE            2850                             2850CLARK            2450                             2450SCOTT            3000                             3000KING                5000                              5000TURNER           1500          0              1500ADAMS            1100                           1100JAMES             950                             950FORD             3000                             3000MILLER           1300                           1300已选择15行。

    6、条件表达式

  • 条件表达式中主要有CASE表达式和Decode()函数。

    a、CASE表达式

  • 语法格式为:CASE expr WEHRE comparison_expr1 THEN return_expr1 [WHEN comparison_expr2 THEN return_expr2 ...... WHEN comparison_exprn THEN return_exprn ELSE else_expr] END。
  • 示例:想显示全部雇员的职位,但是这些职位要求替换为中文显示。

        SQL> select empno, ename, case job when 'CLERK' then '办事员' when 'SALESMAE' then '销售' when 'MANAGER' then '经理' when 'ANALYST' then '分析员' else '总裁' end case from emp;         EMPNO ENAME      CASE            7951 EASON      分析员            7369 G_EASON    办事员            7499 ALLEN      总裁            7521 WARD       总裁            7566 JONES      经理            7654 MARTIN     总裁            7698 BLAKE      经理            7782 CLARK      经理            7788 SCOTT      分析员            7839 KING       总裁            7844 TURNER     总裁            7876 ADAMS      办事员            7900 JAMES      办事员            7902 FORD       分析员            7934 MILLER     办事员已选择15行。SQL>

    b、Decode函数

  • 语法格式:DECODE(col | expression, search2, result1, [, search3, result2, ...., ] [, default]。Decode函数和case表达式都可用于IF-THEN-ELSE逻辑判断的。
  • 示例:想显示全部雇员的职位,但是这些职位要求替换为中文显示。
    SQL> select empno, ename, job, decode(job, 'CLERK', '办事员', 'SALESMAN', '销售', 'MANAGER', '经理', 'ANALYST', '分析员', '总裁') from emp;         EMPNO ENAME      JOB       DECODE            7951 EASON      ANALYST   分析员            7369 G_EASON    CLERK     办事员            7499 ALLEN      SALESMAN  销售            7521 WARD       SALESMAN  销售            7566 JONES      MANAGER   经理            7654 MARTIN     SALESMAN  销售            7698 BLAKE      MANAGER   经理            7782 CLARK      MANAGER   经理            7788 SCOTT      ANALYST   分析员            7839 KING       PRESIDENT 总裁            7844 TURNER     SALESMAN  销售            7876 ADAMS      CLERK     办事员            7900 JAMES      CLERK     办事员            7902 FORD       ANALYST   分析员            7934 MILLER     CLERK     办事员已选择15行。

    7、嵌套函数

  • 嵌套函数的执行熟顺序是由内到外。
  • 语法格式:F3(F2(col, arg1), arg2), arg3)。
  • 参照雇员信息表,想显示距聘用日期3个月后的下一个星期一的日期,且日期格式如:2017-01-06。
  • 分析:距聘用日期3个月后:add_months(hiredate, 3),下一个星期一:next_day(add_months(hiredate,3), '星期一'),且日期格式如2017-01-06: to_char(next_day(add_months(hiredate,3), '星期一'), 'YYYY-MM-DD')。
        SQL> select to_char(next_day(add_months(hiredate,3), '星期一'), 'YYYY-MM-DD') new_date from emp;NEW_DATE2018-03-051981-03-231981-05-251981-05-251981-07-061982-01-041981-08-031981-09-141987-07-201982-02-221981-12-141987-08-241982-03-081982-03-081982-04-26已选择15行。
  • 参照雇员信息表,显示雇员日薪并四舍五入到2位小数的结果,然后对薪资格式以:¥1,182.19'这样的例子形式进行格式化。
  • 分析:雇员日薪并四舍五入到2位小数的结果:雇员日薪并四舍五入到2位小数的结果:round(sal/30, 2);对薪资格式以'¥1,182.19'这样的例子形式进行格式化:to_char(round(sal/30, 2), 'L9,999.99')。
    SQL> select to_char(round(sal/30, 2), 'L9,999.99') from emp;TO_CHAR(ROUND(SAL/3                     ¥100.00                        ¥26.67                        ¥53.33                        ¥41.67                        ¥99.17                        ¥41.67                        ¥95.00                        ¥81.67                     ¥100.00                     ¥166.67                        ¥50.00                        ¥36.67                        ¥31.67                     ¥100.00                        ¥43.33已选择15行。
0