(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;