oracle 9 插入日期,oracle date日期类型 精析
一、date
1.date、sysdate格式说明
展示
date类型,展示格式既可以为:YYYY/MM/DD,也可以为YYYY/MM/DD HH24:MI:SS;
其存储格式只有一种:YYYY/MM/DD HH24:MI:SS
展示格式一:
当你只存年月日时,date实际存储的是:年月日0时0分0秒,在plsql中,其展示格式为:YYYY/MM/DD,
将其转换成YYYY/MM/DD HH24:MI:SS时,返回的是YYYY/MM/DD 00:00:00。
展示格式二:
当date实际存储的是年月日时分秒时,在plsql中,其展示格式为:YYYY/MM/DD HH24:MI:SS;
系统时间sysdate,在plsql中,其展示格式为:YYYY/MM/DD HH24:MI:SS。
说明:与插入时的格式无关
证实
TESTDATE表结构
插入sql的日期格式及结果展示
补充:
当插入年月日时分秒且时分秒为:00:00:00,在plsql中是不显示时分秒的。
要想显示出来,需用to_char()
若是还是对推荐有疑问,请看下面的 4.2 查询指定时间段的数据
2.日期转字符串
TO_CHAR(date,format)
方式一:只带一个参数
select to_char(t.schedule_date) from CONSULT_SCHEDULE t
--28-APR-17
方式二:带2个参数
转换格式不区分大小写;
小时格式化:不带24时,默认为12小时制,24小时格式转换时需要指明;
分钟格式化:可以使用mi或mm,建议使用MI。
说明:
格式化成yyyy年mm月dd日
--年月日
--需要填充3个空格,不然‘日’显示不出来
SELECT TO_CHAR(SYSDATE,'yyyy"年"MM"月"dd"日" ') 系统日期 FROM DUAL
注意:
年月日需加上双引号;
别名不能加单引号、双引号。
3.字符串转日期
方法一:
TO_DATE('dateStr', format),规则如下:
转换格式不区分大小写;
小时格式化:不带24时,默认为12小时制,24小时格式转换时需要指明;
分钟格式化:必须使用mi,不能使用mm,否则会报错;
dateStr的长度<=format的长度,都可以实现类型转换:
方式一:标准格式
年月日
说明:
年月日时分秒
方式二:字符串只到分,会自动添加上:00秒。
方式三:字符串也是只到日
方法二:
DATE'YYYY-MM-DD',并且只能是这一种格式。
另外,TO_DATE(date),该函数也可以只传一个参数,但是这个参数必须是date类型,
表示的含义是:将任何格式的日期类均转换成YYYY/MM/DD的格式。
4.根据日期查询数据
说明:这里着重介绍的是日期字段带有时分秒的
4.1 查询某一天的数据
测试环境:
VIRTUAL_CARD表中共有5条记录;
字段REGTIME的字段类型为date。
情景模拟:查询2018年7月18日的数据记录
格式要求:日期转变成YYYY-MM-DD HH24:MI:SS格式的字符串
方式一:查询条件使用字符串实现
--查询条件按字符串进行
SELECT TO_CHAR(T.REGTIME, 'YYYY-MM-DD HH24:MI:SS') REGTIME
FROM VIRTUAL_CARD T
WHERE TO_CHAR(T.REGTIME, 'yyyy-mm-dd') = '2018-07-18'
方式二:查询条件使用日期实现
方法一:TRUNC()
--查询条件按日期进行1
SELECT TO_CHAR(T.REGTIME, 'YYYY-MM-DD HH24:MI:SS') REGTIME
FROM VIRTUAL_CARD T
WHERE TRUNC(T.REGTIME) = TO_DATE('2018-07-18', 'YYYY-MM-DD')
方法二:TO_DATE()
--查询条件按日期进行2
SELECT TO_CHAR(T.REGTIME, 'YYYY-MM-DD HH24:MI:SS') REGTIME
FROM VIRTUAL_CARD T
WHERE TO_DATE(T.REGTIME) = TO_DATE('2018-07-18', 'YYYY-MM-DD')
方式三:利用TO_DATE()特性
SELECT TO_CHAR(T.REGTIME, 'YYYY-MM-DD HH24:MI:SS') REGTIME
FROM VIRTUAL_CARD T
WHERE T.REGTIME >= TO_DATE('2018-07-18', 'YYYY-MM-DD')
AND T.REGTIME < TO_DATE('2018-07-19', 'YYYY-MM-DD')
方法四:TO_CHAR()-->TO_DATE() 不建议使用
SELECT TO_CHAR(T.REGTIME, 'YYYY-MM-DD HH24:MI:SS') REGTIME
FROM VIRTUAL_CARD T
WHERE TO_DATE(TO_CHAR(T.REGTIME, 'YYYY-MM-DD'), 'YYYY-MM-DD') =
TO_DATE('2018-07-18', 'YYYY-MM-DD')
查询结果展示
updateTime--2018年8月15日10点21分
4.2 查询指定时间段的数据
表数据展示
场景:查询从2018-08-05至2018-08-06的数据
错误实现方式:
--错误实现:between and
SELECT REGTIME
FROM VIRTUAL_CARD
WHERE REGTIME BETWEEN TO_DATE('2018-08-05', 'yyyy-mm-dd') AND
TO_DATE('2018-08-07', 'yyyy-mm-dd')
ORDER BY REGTIME
查询结果:[2018/08/05 00:00:00,2018/08/07 00:00:00]
方式一:
--方式一:[2018/08/05 00:00:00,2018/08/06 23:59:59]
SELECT REGTIME
FROM VIRTUAL_CARD
WHERE REGTIME >= TO_DATE('2018-08-05', 'yyyy-mm-dd') AND
REGTIME < TO_DATE('2018-08-07', 'yyyy-mm-dd')
ORDER BY REGTIME
方式二:推荐使用
--方式二:[2018/08/05 00:00:00,2018/08/07 00:00:00)
SELECT REGTIME
FROM VIRTUAL_CARD
WHERE REGTIME >= TO_DATE('2018-08-05', 'yyyy-mm-dd') AND
REGTIME < TO_DATE('2018-08-06', 'yyyy-mm-dd') + 1 --2018-08-07
ORDER BY REGTIME
方式三:
--方式三
SELECT REGTIME
FROM VIRTUAL_CARD
WHERE REGTIME >= TO_DATE('2018-08-05 00:00:00', 'yyyy-mm-dd hh24:mi:ss') AND
REGTIME <= TO_DATE('2018-08-06 23:59:59', 'yyyy-mm-dd hh24:mi:ss')
ORDER BY REGTIME
5.date类型进行加减运算
二、timestamp
1.格式
--查询系统时间戳
SELECT SYSTIMESTAMP FROM DUAL
三、相互转换
1.日期转时间戳
--系统时间转时间戳
SELECT CAST(SYSDATE AS TIMESTAMP) DATE_TO_TIMESTAMP FROM DUAL
写在最后
哪位大佬如若发现文章存在纰漏之处或需要补充更多内容,欢迎留言!!!
oracle 9 插入日期,oracle date日期类型 精析相关推荐
- java.text.dateformat_使用java.text.SimpleDateFormat类进行文本日期和Date日期的转换
Date类内部既不存储年月日也不存储时分秒,而是存储一个从1970年1月1日0点0分0秒开始的毫秒数,而真正有用的年月日时分秒毫秒都是从这个毫秒数转化而来,这是它不容易被使用的地方,尤其是显示和存储的 ...
- ios swift5 时间戳 时间差 日期格式 Date 日期字符串
1.日期Date转日期字符串(格式) @objc func chooseDate(_ datePicker:UIDatePicker) {let chooseDate = datePicker.dat ...
- oracle批量插入优化,oracle批量插入优化方案
今天听DBA说如果从一个表批量查询出一批数据之后批量插入另外一张表的优化方案: 1)不写归档日志: 2)采用独占 关于insert /*+ append */我们需要注意以下三点: a.非归档模式下, ...
- oracle 日期类型是什么,oracle date日期类型 精析
一.date 1.date.sysdate格式说明 展示 date类型,展示格式既可以为:YYYY/MM/DD,也可以为YYYY/MM/DD HH24:MI:SS: 其存储格式只有一种:YYYY/MM ...
- oracle 函数插入操作,Oracle函数内部运用insert插入
Oracle函数内部使用insert插入 create or replace function GET_PRODUCT_ID_BY_NAME(productName varchar2) return ...
- oracle数据插入覆盖,oracle数据库覆盖导入
oracle数据库备份(导入导出dmp)_IT/计算机_专业资料.包括远程连接 ... oracle数据库导入导出命令_计算机软件及应用_IT/计算机_专业资料.Oracle 数据导入导出 imp/e ...
- oracle高效插入数据,Oracle:高效插入大量数据经验之谈
[IT168 评论]在很多时候,我们会需要对一个表进行插入大量的数据,并且希望在尽可能短的时间内完成该工作,这里,和大家分享下我平时在做大量数据insert的一些经验. 前提:在做insert数据之前 ...
- 新手小白学JAVA 日期类Date SimpleDateFormat Calendar
1. Date日期类 类 Date 表示一个特定的瞬间,精确到毫秒 1.1 Date的构造函数 Date() 分配一个 Date 对象,以表示分配它的时间(精确到毫秒) Date(long date) ...
- Oracle根据日期区间查询Date类型的数据
在Oracle数据库中,根据日期区间查询Date类型的数据 select proposalno,policyno,enddate from 表名 where 时间字段 between to_date( ...
最新文章
- HTML5和css3的总结
- Android 动态Tab分页效果实现
- Spring Cloud Alibaba - 24 Gateway-路由、断言(Predicate)、过滤器(Filter)初体验
- 12月9日 php环境的安装和基本知识的学习
- 文献学习(part78-B)--A Survey of Clustering Algorithms for Big Data: T axonomy Empirical Analysis
- 1049. 数列的片段和(20)
- SSH隧道技术----端口转发,socket代理
- postmapping注解_Swagger常用注解
- 系统架构设计师含金量_软考高级系统架构设计师如何备考?
- pythonnumpy矩阵详解_python常用模块numpy解析(详解)
- Altium Designer 10 安装破解教程
- UI - PS如何导入不同的字体
- 【图论】欧拉通路和哈密顿通路
- 【电驱动】驱动电机系统讲解
- deepin linux 命令行_deepin-linux常用命令大全----每天一个linux命令 - 子成君-分享出去,快乐加倍!-旧版已停更...
- java 合并mp3
- android 桌面快捷方式静态shortcuts异常
- mysql(数据库)初级操作
- Twitter账号老被封?一文教会你怎么养号
- 中国科学院大学计算机考研好考吗,中国科学院大学考研难吗?一般要什么水平才可以进入?...