视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
TIMESAMPE_HEX_TO_CHAR函数解决时间16进制可视化问题
2020-11-09 14:10:35 责编:小采
文档

在11G 提供了一个超过4秒的SQL视图 里面包含了很多必要的信息 同时可以使用 --查看超过4秒语句执行计划 获得个格式美化的东西 可是其中 Binds TIMESTAMP 却是16进制. 如何让它变得萌萌哒呢? 如果简单的16进制换算成10进制 我们可以用WINDOWS的计算器来玩, 可

 
在11G 提供了一个超过4秒的SQL视图 里面包含了很多必要的信息 同时可以使用

--查看超过4秒语句执行计划
SELECT dbms_sqltune.report_sql_monitor(sql_id => '&sql_id',report_level => 'ALL',type=>'TEXT') comm FROM dual;

获得个格式美化的东西

可是其中

Binds
========================================================================================================================
| Name | Position | Type | Value |
========================================================================================================================
| :1 | 1 | TIMESTAMP | 78720C0D010101 |
| :2 | 2 | TIMESTAMP | 78720C0D183C3C |
| :3 | 3 | NUMBER | 3 |
| :4 | 4 | NUMBER | 10000978 |
| :5 | 5 | TIMESTAMP | 78720C0D010101 |
| :6 | 6 | TIMESTAMP | 78720C0D183C3C |
| :7 | 7 | NUMBER | 10000978 |
| :8 | 8 | NUMBER | 2 |
| :9 | 9 | NUMBER | 1000 |
| :10 | 10 | NUMBER | 0 |
========================================================================================================================

TIMESTAMP 却是16进制.

如何让它变得萌萌哒呢?

如果简单的16进制换算成10进制 我们可以用WINDOWS的计算器来玩, 可是这是时间啊,ORACLE时间存储规则不一样哦.对了其实也是数字存储方式的

另外还有正负数,小数,指数.

当然我们这里个时间类型 包含 年份 日期 时间 毫秒. 这四个部分算法是不一样的.

你可以SELECT DUMP(SYSDATE) FROM DUAL 出来对比了解下

啰嗦 上函数. 不够这函数解决年月日和时间

create or replace function hex_to_date(hexstr in varchar2) return timestamp as
begin
 if length(hexstr) <> 14 then
 return null;
 end if;

 return to_timestamp(to_char(to_number(substr(hexstr, 1, 2), 'xx') - 100,
 'fm00') ||
 to_char(to_number(substr(hexstr, 3, 2), 'xx') - 100,
 'fm00') ||
 to_char(to_number(substr(hexstr, 5, 2), 'xx'),
 'fm00') ||
 to_char(to_number(substr(hexstr, 7, 2), 'xx'),
 'fm00') ||
 to_char(to_number(substr(hexstr, 9, 2), 'xx') - 1,
 'fm00') ||
 to_char(to_number(substr(hexstr, 11, 2), 'xx') - 1,
 'fm00') ||
 to_char(to_number(substr(hexstr, 13, 2), 'xx') - 1,
 'fm00'),
 'yyyymmddhh24miss');
end;


下载本文
显示全文
专题