4 数据查询中的函数使用

(1)查找并替换字符串 REPLACE(FIELD,oldValue,newValue)

--查询并将SDEPT字段的值‘计算机’改为‘COMPUTER’
SELECT REPLACE(SDEPT,'计算机','COMPUTER') 所在班级
FROM STU;

(2)获取字符的ASCII码 ASCII(char)

--分别输出‘A’‘Z’‘0’‘ ’四个字符的ASCII码值
SELECT ASCII('A') A,ASCII('Z') Z,ASCII('0') ZERO,ASCII(' ') SPACE
FROM DUAL;

(3)字段长度  LENGTH(value)

SELECT SANME,LENGTH(SANME),SDEPT,LENGTH(SDEPT)
FROM STU WHERE SNO='12001';

LENGTH函数不仅可以统计字符串的长度,还可以统计数值位数。

(4)使用ROUND确定精度  ROUND(NUMBER,decimal_places)

--设置精度为小数点后三位
SELECT ROUND(AVG(SAGE),3) 平均年龄
FROM STU;

ROUND函数位数取负时,对整数部分进行四舍五入。例:ROUND(123.344,-2) : 100    ROUNG(156.33,-2)  :  200

(5)日期时间操作  日期格式,CEIL,FLOOR,MONTHS_BETWEEN,TRUNC

--将日期往后推一年    ADD_MONTHS(DATE,NUMBER)  
SELECT SNO,SANME,ADD_MONTHS(SBIRTH,12) FROM STU;
--日期格式化为字符串  TO_CHAR(d|n[,fmt])
SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS') FROM DUAL;
--特定日期时间的提取  HOUR提取没加时区
--也可用ROUND()实现,会舍去相应部分  例:ROUND(SYSDATE,'YEAR')
SELECT SYSDATE 当前日期时间,
EXTRACT(YEAR FROM SYSDATE) 年份,
EXTRACT(MONTH FROM SYSDATE) 月份,
EXTRACT(DAY FROM SYSDATE) 日,
EXTRACT(HOUR FROM SYSTIMESTAMP) 时,
EXTRACT(MINUTE FROM SYSTIMESTAMP) 分,
EXTRACT(SECOND FROM SYSTIMESTAMP) 秒
FROM DUAL;
--提取日期的星期值  区分 ‘D’显示的为日期数字
SELECT TO_CHAR(SYSDATE,'DAY') FROM DUAL;
--提取日期为一年内的第几天
SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;
--计算时间差的天数
--月份使用 CEIL(MONTHS_BETWEEN(DATE1,DATE2))
SELECT FLOOR(TO_NUMBER(SYSDATE-TO_DATE('2017-11-02','YYYY-MM-DD'))) AS SPANDAYS
FROM DUAL;
--获取某月的第一天和最后一天
SELECT TRUNC(TRUNC(SYSDATE,'MONTH')-1,'MONTH') FIRST_DAY_LAST_MONTH,
TRUNC(SYSDATE,'MONTH')-1/86400 LAST_DAY_LAST_MONTH,
TRUNC(SYSDATE,'MONTH') FIRST_DAY_CUR_MONTH,
LAST_DAY(TRUNC(SYSDATE,'MONTH'))+1-1/86400 LAST_DAY_CUR_MONTH
FROM DUAL;

日期格式化的其它形式:YYYY/MM/DD 年/月/日,YYYY 年(4位),YYY  年(3位),YY  年(2位),MM  月份,DD  日期,D  星期(周日到周六分别对应1-7),DDD  一年的第几天,WW  一年的第几周,W  一月的第几周,HH24:MI:SS  时(24小时制)分秒,HH:MI:SS  时(非24时)分秒

*对日期进行的算术运算是以天数进行的运算,+100表示往后推迟一百天

(6)数据类型转换

SELECT TO_CHAR(-12332.78,'L9.9EEEEPR') 科学计数法
FROM DUAL;
SELECT TO_NUMBER('-$12,345.67','$99,999.99') 数字
FROM DUAL;

字符串格式化输出符:(9  指定位置显示数字),(.  指定位置返回小数点),(,  指定位置返回逗号),($  指定位置返回美元符号),(EEEE  科学计数法表示),(L  数字前加本地货币),(PR  如果数字为负数,则用尖括号表示)

(7)NAV函数的使用

--NVL(X,VALUE)  NVL2(X,VALUE1,VALUE2)
--值为空,加200  否则加一百
SELECT ENO,ENAME,SALARY,
NVL2(COMM,COMM+100,200) 加发奖金
FROM SALARY WHERE SALARY<3000;

 

你可能感兴趣的:(oracle数据库,Oracle数据库系列学习)