Oracle计算时间差常用函数
admin
2023-04-15 11:02:19
0

Oracle计算时间差常用函数
两个Date类型字段:START_DATE,END_DATE,计算这两个日期的时间差(分别以天,小时,分钟,秒,毫秒):
天:
ROUND(TO_NUMBER(END_DATE - START_DATE))


ROUND(TO_NUMBER(END_DATE - START_DATE) * 24)


ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60)


ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60)

毫秒
ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 1000)


十分钟前
select  sysdate -10/(60*24)   from dual 

select
status,
continued_time, /*时间单位为秒*/
sid,
sql_id,
username,
FIRST_REFRESH_TIME,
LAST_REFRESH_TIME,
SQL_TEXT,
ERROR_NUMBER,
ERROR_MESSAGE
from
(
select
status,
ROUND(TO_NUMBER(LAST_REFRESH_TIME - FIRST_REFRESH_TIME) * 24 * 60 * 60 ) as continued_time , /*时间为秒*/
sid,
sql_id,
username,
FIRST_REFRESH_TIME,
LAST_REFRESH_TIME,
SQL_TEXT,
ERROR_NUMBER,
ERROR_MESSAGE,
row_number() OVER(PARTITION BY sql_id ORDER BY t.LAST_REFRESH_TIME desc) as row_flg
from
gv$sql_monitor t
----where t.LAST_REFRESH_TIME > sysdate -10/(60*24) ------采集当前时间10分钟内的
)
temp
where temp.row_flg=1

Oracle去除重复(某一列的值重复),取最新(日期字段最新)的一条数据

解决思路:用Oracle的row_number() over函数来解决该问题。
解决过程:
 1.查看表中的重复记录
select
    t.id,
    t.device_id,
    t.update_dtm,
    t.test_result
from DEVICE_INFO_TBL t


2.标记重复的记录
select
    t.id,
    t.device_id,
    t.update_dtm,
    t.test_result,
    row_number() OVER(PARTITION BY device_id ORDER BY t.update_dtm desc) as row_flg  
from DEVICE_INFO_TBL t


3.过滤重复数据,取得最新的记录
select
    temp.id,
    temp.device_id,
    temp.update_dtm,
    temp.test_result
from (
         select
             t.id,
             t.device_id,
             t.update_dtm,
             t.test_result,
             row_number() OVER(PARTITION BY device_id ORDER BY t.update_dtm desc) as row_flg  
          from DEVICE_INFO_TBL t ) temp
where temp.row_flg  = '1'


row_number() OVER (PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的).
与rownum的区别在于:使用rownum进行排序的时候是先对结果集加入伪列rownum然后再进行排序,而此函数在包含排序从句后是先排序再计算行号码.
row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开时排序).
rank()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内).
dense_rank()l是连续排序,有两个第二名时仍然跟着第三名。相比之下row_number是没有重复值的 .
lag(arg1,arg2,arg3):
arg1是从其他行返回的表达式
arg2是希望检索的当前行分区的偏移量。是一个正的偏移量,时一个往回检索以前的行的数目。
arg3是在arg2表示的数目超出了分组的范围时返回的值。


相关内容

热门资讯

【今日要闻】“毛豆大厅拼三张到... 【今日要闻】“毛豆大厅拼三张到底有挂吗?”(必胜开挂神器)您好,毛豆大厅拼三张这个游戏其实有挂的,确...
单膝跪地勇救脑梗登山客 黄河科... “要不是这位同学,后果不堪设想!”12月24日上午,在黄河科技学院职业技术学院会议室内,被救者王叔的...
俄年度热词聚焦“胜利”“人工智... 新华社莫斯科12月28日电2025年即将结束,俄罗斯多个机构和团体分别推出本国年度热词榜单,上榜热词...
关于微信占存储空间的几个误解 (来源:JSTV荔枝视频) 转自:JSTV荔枝视频 #教你1招快速深度清理手机缓存#【#关于微信占存...
今日重大通报“天天爱麻将究竟有... 今日重大通报“天天爱麻将究竟有挂吗?”(必胜开挂神器)您好,天天爱麻将这个游戏其实有挂的,确实是有挂...
【第一资讯】“阿拉斗牌辅助器?... 网上科普关于“阿拉斗牌有没有挂”话题很是火热,小编也是针对阿拉斗牌作*弊开挂的方法以及开挂对应的知识...
玩家攻略科普“牌乐门到底是不是... 家人们!今天小编来为大家解答牌乐门透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很多...
【第一资讯】“决胜奕福是不是有... 您好:决胜奕福这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
今日重大消息“新版九哥牛牛究竟... 网上科普关于“新版九哥牛牛有没有挂”话题很是火热,小编也是针对新版九哥牛牛作*弊开挂的方法以及开挂对...
我来教教您“可乐麻将开挂神器?... 网上科普关于“可乐麻将有没有挂”话题很是火热,小编也是针对可乐麻将作*弊开挂的方法以及开挂对应的知识...