Oracle命令(四)--日期函数

 

--sysdate:输出默认时间 日-月-年

 

select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual; //按照指定格式输出时间信息

 

--日期的运算

计算:入职时间,天,周,月,年

select ename,(sysdate-hiredate) 天, (sysdate-hiredate)/7 周,(sysdate-hiredate)/30 月,(sysdate-hiredate)/365from emp

 

日期的四舍五入

select round (sysdate, 'MONTH') from dual;
select round (sysdate, 'YEAR') from dual;
select TRUNC (sysdate, 'MONTH') from dual;
select TRUNC (sysdate, 'YEAR') from dual;

 


SQL显示转化

 

字符串->数字

 

select '111' + 222 from dual;    //'111'字符串转成了数字 111

 

数字->字符串

select '111' || 222 from dual;    //将 222数字转化成了字符串 '222'

 

字符串->日期

select * from emp where hiredate > to_date('1981-01-01', 'yyyy-mm-dd');

 

日期->字符串

--查询 比 19810101 入职晚点的员工

 

select * from emp where to_char(HIREDATE, 'yyyy-mm-dd') > '19810101' 

to_char函数对数字的转化

 

--查询员工的薪水:两位小数 本地货币代码 千位符

 

select ename,to_char(sal, 'L9,999,99') from emp

 

to_number函数
将 某一个格式的 字符串转化成数字

通用函数


nvl2(a,b,c); 当 a = null 的时候, 返回 b, 否则就返回 c。 ==> return a == NULL ? b : c;
nullif(a,b); //当 a = b 时,返回null,否则返回 a
coalsece(a,b,c...); //从左到右返回第一个不为空的

条件表达式(if-then-else):做报表

复制代码
select ename, sal 涨钱工资, sal 涨后工资 from emp;
select ename,job, sal 涨前工资,
(
CASE job WHEN 'PRESIDENT' THEN sal + 1000
WHEN 'MANAGER'    THEN sal + 800
ELSE sal+500
END
)
涨后工资
from emp
复制代码

 

posted @   王清河  阅读(441)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示