【Oracle学习笔记】单行函数

前端之家收集整理的这篇文章主要介绍了【Oracle学习笔记】单行函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

写在前面:

单行函数的概念:

单行函数:接受一个数据,输出一个数据;
多行函数:聚合函数,分组函数。接受一组数据,输出一个数据。

常见字符函数

大小写相关: LOWER,UPPER,INITCAP
其他:TRIM,LTRIM,RTRIM,LPAD,PPAD,INSTR,SUBSTR,LENGTH,CONCAT,REPLACE

  • LOWER会将所有字符转换为小写
  • UPPER会将所有字符转换为大写
  • INITCAP会将首字母转换为大写

example:

SELECT lower(@H_301_35@'Hello'),upper(@H_301_35@'Hello'),initcap(@H_301_35@'Hello') FROM dual;
  • TRIM从字符串的首尾去掉特定字符
  • LTRIM从字符串的首部去掉特定字符
  • RTRIM从字符串的尾部去掉特定字符

example:

SELECT trim(@H_301_35@'H' FROM @H_301_35@'HelloHH'),ltrim(@H_301_35@'HelloHH',@H_301_35@'H'),rtrim(@H_301_35@'HelloHH',@H_301_35@'H') FROM dual;
  • LPAD向左补齐
  • PPAD向右补齐

grammar : lpad(数值,多少位,填充内容) rpad(数值,填充内容)

example :

SELECT lpad(1000,7,@H_301_35@'*'),rpad(1000,@H_301_35@'*') FROM dual;
  • INSTR 查找字符串的位置(注意:在Oracle中,字符串的位置是从1开始的

grammar : instr(原来的字符串,要查找位置的字符串)

example :

SELECT instr(@H_301_35@'hello tom',@H_301_35@'tom') FROM dual;
  • SUBSTR 求字串,从某个位置到开始截取一定长度

grammar : substr(字符串,从哪个位置开始截取,截取多少个字符[不写则截取到最后一个])

example:

SELECT substr(@H_301_35@'hello',3,2) FROM dual;
  • LENGTH 求字符串的长度

example :

SELECT length(@H_301_35@'tom') FROM dual;
  • CONCAT 连接两个字符串

example :

SELECT concat(@H_301_35@'tom',@H_301_35@'my') FROM dual;
  • REPLACE替换字符串

example:

SELECT replace(@H_301_35@'hello',@H_301_35@'h',@H_301_35@'xxx') FROM dual;

常用字符函数例子整合:

SELECT lower(@H_301_35@'Hello'),initcap(@H_301_35@'Hello') FROM dual;

SELECT trim(@H_301_35@'H' FROM @H_301_35@'HelloHH'),@H_301_35@'H') FROM dual;

SELECT lpad(1000,@H_301_35@'*') FROM dual;

SELECT instr(@H_301_35@'hello tom',@H_301_35@'tom') FROM dual;

SELECT substr(@H_301_35@'hello',2) FROM dual;

SELECT length(@H_301_35@'tom') FROM dual;

SELECT concat(@H_301_35@'tom',@H_301_35@'my') FROM dual;

SELECT replace(@H_301_35@'hello',@H_301_35@'xxx') FROM dual;

常见数值函数

  • ROUND四舍五入

example :

SELECT round(123.456,2),round(123.456,-2),round(123.45,0),round(123.456)
FROM dual;

round(123.456,2)小数点两位后四舍五入
round(123.456,-2)小数点前两位四舍五入
round(123.45,0)按照小数点四舍五入
round(123.456)与round(123.456,0)相同

  • TRUNC去尾

example :

SELECT trunc(12.456,trunc(123.456,trunc(123.45,trunc(123.456)
FROM dual;

trunc(12.456,2)小数点后保留两位
trunc(123.456,-2)小数点前保留两位
trunc(123.45,0)按照小数点保留
trunc(123.456)与trunc(123.456,0)相同

  • MOD求模

example :

SELECT mod(12,5) FROM dual;

常用数值函数例子整合:

SELECT round(123.456,round(123.456)
FROM dual;

SELECT trunc(12.456,trunc(123.456)
FROM dual;

SELECT mod(12,5)
FROM dual;

常见日期函数

  • SYSDATE获取系统当前日期

example :

SELECT sysdate FROM dual;
  • MONTHS_BETWEEN获取两个日期间的相差月数

example : 获取emp表中员工的入职日期到今天相差的月数

SELECT ename,months_between(sysdate,hiredate) FROM emp;
  • ADD_MONTH获取几个月后的日期

exmaple : 获取三个月以后的日期

SELECT add_months(sysdate,3) FROM dual;
  • LAST_DAY获取本月最后一天的日期

example :

SELECT last_day(sysdate) FROM dual;
  • EXTRACT从日期中获取某一部分值

example : 获取当前日期的年份

SELECT extract(YEAR FROM sysdate) FROM dual;

example : 获取当前日期的月份

SELECT extract(MONTH FROM sysdate) FROM dual;

example : 获取当前日期的号数

SELECT extract(DAY FROM sysdate) FROM dual;

常见日期函数例子整合:

SELECT sysdate FROM dual;

SELECT ename,hiredate) FROM emp;

SELECT add_months(sysdate,3) FROM dual;

SELECT last_day(sysdate) FROM dual;

SELECT extract(YEAR FROM sysdate) FROM dual;

SELECT extract(MONTH FROM sysdate) FROM dual;

SELECT extract(DAY FROM sysdate) FROM dual;

常见转换函数

  • TO_CHAR将日期或数值转换为指定格式的字符

example : 将日期转换为指定格式的字符

SELECT to_char(sysdate,@H_301_35@'YYYY-MM-DD DAY HH24:MM:SS') FROM dual;

example : 将数值转换为指定格式的字符

SELECT to_char(123.45,@H_301_35@'L9,999,999.00') FROM dual;

其中L表示当地字符,00 表示小数点后如果没有两位小数,则用0填充

  • TO_DATE将指定格式字符转换为日期

example :

SELECT to_date(@H_301_35@'1980-01-01',@H_301_35@'YYYY-MM-DD') FROM dual;
  • TO_NUMBER将指定格式字符串转换为数值

example :

SELECT to_number(@H_301_35@'$1,222.34',@H_301_35@'$9,999.99') FROM dual;

常见转换函数例子整合:

SELECT to_char(sysdate,@H_301_35@'YYYY-MM-DD DAY HH24:MM:SS') FROM dual;

SELECT to_char(123.45,999.00') FROM dual;

SELECT to_date(@H_301_35@'1980-01-01',@H_301_35@'YYYY-MM-DD') FROM dual;

SELECT to_number(@H_301_35@'$1,999.99') FROM dual;

其他函数

空值转换函数

  • NVL字段为空,则用相同类型替代

example :

SELECT ename,comm,nvl(comm,0) FROM emp;

如果字段comm为空,则用与comm数值类型相同的0代替

  • NVL2如果字段为空,则返回第二个参数,反之则返回第三个参数

example :

SELECT ename,nvl2(comm,0,sal) FROM emp;

如果comm字段为空,则用0代替,如果不为空,则用sal代替

  • NULLIF两个字段相同,则为空,否则返回第一个参数的值

exmaple :

SELECT nullif(@H_301_35@'123',@H_301_35@'123') FROM dual;

控制转换函数例子整合:

SELECT ename,0) FROM emp;

SELECT ename,sal) FROM emp;

SELECT nullif(@H_301_35@'123',@H_301_35@'123') FROM dual;

条件分支函数

  • CASE

example :

SELECT ename,deptno,sal,CASE deptno WHEN 10 THEN sal + 100 WHEN 20 THEN sal + 200 WHEN 30 THEN sal + 300 ELSE sal END AS salary FROM emp;
  • DECODE

example : 按照部门号码进行薪资的增加,部门号为10,薪资增加100,部门号为20薪资增加200,部门号为30,薪资增加300,其他则没有变化

SELECT ename,decode(deptno,10,sal + 100,20,sal + 200,30,sal + 300,sal) AS salary FROM emp;
SELECT ename,CASE WHEN deptno = 10 THEN sal +100 WHEN deptno = 20 THEN sal +200 WHEN deptno = 30 THEN sal +300 ELSE sal END AS salary FROM emp;

decode是一个函数, case是一个表达式
但是case有更强大的能力

条件分支函数例子整合:

SELECT ename,sal) AS salary FROM emp;            

SELECT ename,CASE deptno WHEN 10 THEN sal + 100 WHEN 20 THEN sal + 200 WHEN 30 THEN sal + 300 ELSE sal END AS salary FROM emp;

SELECT ename,CASE WHEN deptno = 10 THEN sal +100 WHEN deptno = 20 THEN sal +200 WHEN deptno = 30 THEN sal +300 ELSE sal END AS salary FROM emp;

猜你在找的Oracle相关文章