-----------------------------oracle数据库函数-------------------------------------
---数学函数***
select abs(-1) from dual;
--向上取整
select ceil(2.5)from dual;
select ceil(-2.4)from dual;
select ceil(-2.6)from dual;

--向下取整
select floor(2.5) from dual;
select floor(-2.5) from dual;
select floor(-2.6) from dual;

--四舍五入 注意:4 5之分
select round(2.4)from dual;
select round(2.5)from dual;
select round(-2.4)from dual;
select round(-2.5)from dual;

--幂 2^3 第一个参数是底数 第二个参数是指数
select power(2,3)from dual;

--平方根
select sqrt(3)from dual;

--截断:用于截取小数位数
--第一个参数是目标参数 第二天参数表示保留的小数位数
select trunc(123.456,2) from dual;
select trunc(123.456,0) from dual;

--取模 取余
select mod(10,3) from dual;

---日期转换函数*****

--时间格式
--yyyy-MM-dd HH:mi:ss
--HH默认24小时制 1-23:59:59
--HH12表示12小时制 1-12

--to_char()将日期转换成字符串
select sysdate from dual;
select to_char(sysdate,'yyyy-MM-dd HH:mi:ss') from dual;

--to_date()将字符串转换成日期
select to_date('2017-11-2','yyyy-MM-dd HH:mi:ss') from dual;

select * from ttt_demo01;
insert into ttt_demo01 values(102,'scott',200.99,to_date('1992-11-2','yyyy-MM-dd HH:mi:ss'));

--转换含有数字的字符串
select to_number('1233.456') from dual;

SELECT TO_TIMESTAMP('2016-12-12 12:23:34', 'YYYY-MM-DD HH:MI:SS') FROM DUAL;
--添加了时区
SELECT TO_TIMESTAMP_TZ('2016-12-12 12:23:34 8:00', 'YYYY-MM-DD HH24:MI:SS TZH:TZM') FROM DUAL;

---日期操作函数*****

--截取目标日期里的时间,比如获取当前系统时间的年、月、日
--注意在截取当前系统时间的年月日,可以直接写成 year/month/day from sysdate
--但是hour minute second不可以这么写,需要先转换成字符串,再转换成日期
select extract( year from sysdate) from dual;
select extract( month from sysdate) from dual;
select extract( day from sysdate) from dual;

select extract( second from to_timestamp(to_char(sysdate,'YYYY-MM-DD HH24:MI:SS'),'YYYY-MM-DD HH24:MI:SS')) from dual;

select extract(hour from TO_TIMESTAMP('2016-12-12 12:23:34', 'YYYY-MM-DD HH24:MI:SS')) from dual;
select extract(minute from TO_TIMESTAMP('2016-12-12 12:23:34', 'YYYY-MM-DD HH24:MI:SS')) from dual;
select extract(second from TO_TIMESTAMP('2016-12-12 12:23:34', 'YYYY-MM-DD HH24:MI:SS')) from dual;

--计算月差:两个日期之间相差的月数
--注意:计算结果是第一个参数减第二个参数
select months_between(sysdate,to_date('1995-11-11','YYYY-MM-DD HH:mi:ss'))from dual;

select months_between
(to_date('1980-11-1','YYYY-MM-DD HH:mi:ss'),
to_date('1995-11-11','YYYY-MM-DD HH:mi:ss'))from dual;

--添加月数
select add_months(sysdate,2)from dual;
select add_months(to_date('2017-11-1','YYYY-MM-DD HH:mi:ss'),-13)from dual;

--获取当前系统时间以后的时间(星期)
--一周的组合以下周的日期(本周已过的日期或者正在过的日期)
--和本周的日期(本周还未过的日期)加起来
select next_day(sysdate,'Monday') from dual;--下周一
select next_day(sysdate,'Tuesday') from dual;--下周二
select next_day(sysdate,'Wednesday') from dual;--下周三
select next_day(sysdate,'Thursday') from dual;--本周四
select next_day(sysdate,'Friday') from dual;--本周五
select next_day(sysdate,'Saturday') from dual;--本周六
select next_day(sysdate,'Sunday') from dual;--本周日

--每个月的最后一天
select last_day(sysdate)from dual;
select last_day(to_date('2016-2-1','YYYY-MM-DD'))from dual;
--对日期的四舍五入
select round(sysdate,'year') from dual;
select round(sysdate,'month') from dual;
--对年的四舍五入 分界点是6月和7月
select round(to_date('2017-6-1','YYYY-MM-DD'),'year') from dual;
select round(to_date('2017-7-1','YYYY-MM-DD'),'year') from dual;
--对月的四舍五入 分界点是15日和16日
select round(to_date('2017-6-1','YYYY-MM-DD'),'month') from dual;
select round(to_date('2017-6-15','YYYY-MM-DD'),'month') from dual;
select round(to_date('2017-6-16','YYYY-MM-DD'),'month') from dual;

select round(to_date('2016-2-15','YYYY-MM-DD'),'month') from dual;
select round(to_date('2016-2-16','YYYY-MM-DD'),'month') from dual;

--截取日期
--此处的day表示星期几
--获取离当前时间最近的星期日(已经过了的)
select trunc(sysdate,'day')from dual;
--获取年初
select trunc(to_date('2017-5-5','yyyy-MM-dd'),'year')from dual;
select trunc(to_date('2016-5-5','yyyy-MM-dd'),'year')from dual;

---字符串函数***

--将字符串转换为大写
select upper(username) from t_user;
select lower(username)from t_user;
--拼接字符串
select 'abc'||'def' from dual;
select username||password from t_user;
select concat(username,password)from t_user;
--列的宽度、长度(列值的宽度)
select length(username)from t_user;
--填充
--左填充 第一个参数目标参数,第二个参数 填充完之后的字符串长度
--第三个参数 填充的数据
--该例子是用字符b为字符a做填充
select lpad('a',1,'b')from dual;
select lpad('a',2,'b')from dual;
select lpad('a',3,'b')from dual;

select rpad('a',1,'b')from dual;
select rpad('a',2,'b')from dual;
select rpad('a',3,'b')from dual;
select * from t_user;
--去空
--左去空
select ltrim(username)from t_user;
--右去空
select rtrim(username)from t_user;
--去前后空
select trim(username)from t_user;

--检索字符串(查询某字符串所在的索引位置) oracle中字符串索引从1开始
select instr('abcdefg','c')from dual;
select instr('abcdefg','cff')from dual;
select instr('abcdefg','cde')from dual;

--截取字符串
--两个参数的时候 第一个参数表示目标字符串,第二个参数表示从索引位置开始截取到最后
select substr('abcdefg',2) from dual;
--三个参数的时候 第一个参数表示目标字符串,第二个参数表示从索引位置开始截取
--第三个参数表示截取的长度
select substr('abcdefg',2,5) from dual;

--替换
select replace('abcdefg','a','AAA')from dual;

---其他函数

 

oracle之函数-数字,日期,转换,字符串,其他的更多相关文章

  1. MySQL日期函数与日期转换格式化函数大全

    Mysql作为一款开元的免费关系型数据库,用户基础非常庞大,本文列出了MYSQL常用日期函数与日期转换格式化函数 1.DAYOFWEEK(date) 1 2 SELECT DAYOFWEEK('201 ...

  2. oracle系统函数(日期函数)

    oracle系统函数(日期函数) 调用日期函数时,首先要明确两个概念,时间戳和日期是不同的,日期中包括年月日但不包括小时分钟秒,时间戳包括年月日小时分钟秒.在oracle中,一般情况下,函数中包含da ...

  3. 问题:oracle 字符串转换成日期;结果:[oracle] to_date() 与 to_char() 日期和字符串转换

    to_date("要转换的字符串","转换的格式")   两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,& ...

  4. [oracle] to_date() 与 to_char() 日期和字符串转换

    to_date("要转换的字符串","转换的格式")   两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,& ...

  5. 【转】sql to_char 日期转换字符串

    1.转换函数 与date操作关系最大的就是两个转换函数:to_date(),to_char() to_date() 作用将字符类型按一定格式转化为日期类型: 具体用法:to_date('2004-11 ...

  6. sql to_char 日期转换字符串

    1.转换函数 与date操作关系最大的就是两个转换函数:to_date(),to_char() to_date() 作用将字符类型按一定格式转化为日期类型: 具体用法:to_date('2004-11 ...

  7. Sql server 日期函数和日期转换

    时间函数 SQL Server Date 函数 下面的表格列出了 SQL Server 中最重要的内建日期函数: 函数 描述 GETDATE() 返回当前日期和时间 DATEPART(Type,dat ...

  8. Oracle - Trunc() 函数截取日期&截取数值

    Oracle TRUNC函数可以截取数字和日期类型:截取日期:select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual; --显示当前时间 s ...

  9. AngularJS 日期转换字符串

    日期转换成字符串的办法有很多种,其中最简单的方法是 使用AngularJS的filter来实现. $filter('date')(date, 'yyyyMM'): $filter('date')(da ...

随机推荐

  1. uva 1400 "Ray, Pass me the dishes!" (区间合并 最大子段和+输出左右边界)

    题目链接:https://vjudge.net/problem/UVA-1400 题意:给一串序列,求最大子段,如果有多个,输出字典序最小的那个的左右端点 思路: 之前写过类似的,这个麻烦点需要输出左 ...

  2. WebForm——浅拷贝与深拷贝

    注:本文整理来自连接 https://www.cnblogs.com/echolun/p/7889848.html ,感谢博主的分享 总结: 1.浅拷贝:只拷贝变量的名,而不拷贝变量的值——常为引用类 ...

  3. 配置了Ubuntu环境变量,系统启动不了

    修改了etc/init.d/rcS文件后重启后Ubuntu起不来了, 开启按shift+e或者直接选择,进入恢复模式 进入root shell 执行这个命令 可以有写入权限,重新挂载 mount  - ...

  4. input输入框内容变化实时监听

    js实现的文本框内容发生改变立马触发事件简单介绍:本章节介绍一下如何在文本框的内容发生变化的时候,立马触发一个事件执行响应的操作,而不是像是keydown或者keyup事件一样,只能够检测通过键盘输入 ...

  5. LoadRunner编程之文件的操作

    这篇文章主要写下LoadRunner下如何进行文件的操作. 1,文件的声明 LoadRunner不支持FILE数据类型,所以在LoadRunner中用int来声明一个文件: int MyFile; 2 ...

  6. Pycharm 误删文件夹

    在Linux下操作时误删除了Pycharm项目中的文件夹,打开垃圾桶,居然找不到,立马上网查Linux下怎么恢复文件, 冷静一下,不是还有个Ctrl + Z吗,对着Pycharm 文件浏览器 按一下, ...

  7. 注意了,Mybatis中条件判断时遇到的坑

    1.mapper中比较字符串时需要注意的问题如下: mybatis 映射文件中,if标签判断字符串相等,两种方式:因为mybatis映射文件,是使用的ognl表达式,所以在判断字符串isComplet ...

  8. mingw-w64 gcc std::thread 行为异常

    我用的 ming-w64 gcc 是通过 MSYS2 安装的,包名是 mingw-w64-x86_64-gcc,版本 9.2.0-2. 我发现 std::thread 行为异常. int main() ...

  9. ros 配置udev

    显示已经链接设备 lsusb 显示挂载点 ls /dev/ttyACM* /dev/ttyUSB* 可以看到 ttyUSB0 和 ttyUSB1 对应哪一个设备不确定,因此,我们就需要一种方法来保证每 ...

  10. PHP内存管理-zendMM

    ZendMM 是zend memory manager zendMM可以分为三层: 1.存储层 维护者不同体量内存的hash表,已提供堆层使用,负责向os申请和释放内存 2.堆层 PHP内存管理的核心 ...