博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle取月份,不带前面的0
阅读量:6293 次
发布时间:2019-06-22

本文共 963 字,大约阅读时间需要 3 分钟。

hot3.png

今天碰到只要取月份和天数,如果月份前面有0要去掉0.比如说2010-01-08 ,需要的结果是1-8. 
引出了一系列的sql语句 
第一: 利用to_number的函数转换自动截0 
select to_number(to_char(sysdate,'mm'))||'-'||to_number(to_char(sysdate,'dd')) from dual; 
第二: 利用ltrim函数加固定参数去掉0 
select ltrim(to_char(sysdate,'mm'),'0')||'-'||ltrim(to_char(sysdate,'dd'),'0') from dual; 
上面两种方法实现了我们所需要的,共同的特点是都用到两个函数了,但有没有更简单的方法呢 ? 
我猜有的人肯定就想到了oracle是不是有这样的格式呢 
select to_char(sysdate,'m-d') from dual; 
很可惜,提示错误,日期格式不存在 。不要灰心,我们继续... 
第三:利用函数的特性。 
我们知道 select sysdate from dual ; 
得到的值是:2010-1-8 11:06:18 
那有没有函数直接获取到月份1和日8,我们的猜测是正确的,确实有这样的函数,出现了下面的函数, 
select extract(month from sysdate) ||'-'|| extract(day from sysdate) month from dual; 
注意: extract 具体的用法找'google'吧 ,不会让你失望的。 
又近了一步,满足了吧,不要满足了,下面还有。 上面的方法有一个共同的特征,就是月和日都是分开取的,怎么样才能 
合并到一起去,这样多好啊 ! 看我们的第四种方法: 
第四:巧用oracle自带的格式 
select to_char(sysdate,'
fmmm
-dd') from dual; 
ps:the format_mask parameter begins with 
"FM". This means that zeros and blanks are suppressed

转载于:https://my.oschina.net/swearyd7/blog/168090

你可能感兴趣的文章
mybatis学习
查看>>
LCD的接口类型详解
查看>>
Spring Boot Unregistering JMX-exposed beans on shutdown
查看>>
poi 导入导出的api说明(大全)
查看>>
Mono for Android 优势与劣势
查看>>
将图片转成base64字符串并在JSP页面显示的Java代码
查看>>
js 面试题
查看>>
sqoop数据迁移(基于Hadoop和关系数据库服务器之间传送数据)
查看>>
腾讯云下安装 nodejs + 实现 Nginx 反向代理
查看>>
Javascript 中的 Array 操作
查看>>
java中包容易出现的错误及权限问题
查看>>
AngularJS之初级Route【一】(六)
查看>>
服务器硬件问题整理的一点总结
查看>>
SAP S/4HANA Cloud: Revolutionizing the Next Generation of Cloud ERP
查看>>
Mellanox公司计划利用系统芯片提升存储产品速度
查看>>
白帽子守护网络安全,高薪酬成大学生就业首选!
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>