-
Notifications
You must be signed in to change notification settings - Fork 64
/
Copy pathcs_hexdump_to_timestamp.sql
executable file
·50 lines (50 loc) · 1.51 KB
/
cs_hexdump_to_timestamp.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
----------------------------------------------------------------------------------------
--
-- File name: cs_hexdump_to_timestamp.sql
--
-- Purpose: Convert Hexadecimal Dump to Time
--
-- Author: Carlos Sierra
--
-- Version: 2020/12/06
--
-- Usage: Execute connected to CDB or PDB.
--
-- Example: $ sqlplus / as sysdba
-- SQL> @cs_hexdump_to_timestamp.sql
--
-- Notes: Developed and tested on 12.1.0.2.
--
---------------------------------------------------------------------------------------
--
DEF timestamp_as_hexdump = '&1.';
--
SET HEA ON LIN 2490 PAGES 100 TAB OFF FEED OFF ECHO OFF VER OFF TRIMS ON TRIM ON TI OFF TIMI OFF LONG 240000 LONGC 2400 NUM 20 SERVEROUT OFF;
ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY-MM-DD"T"HH24:MI:SS';
ALTER SESSION SET NLS_TIMESTAMP_FORMAT = 'YYYY-MM-DD"T"HH24:MI:SS.FF6';
--
COL time FOR A20;
COL timestamp FOR A30;
--
WITH
FUNCTION get_date (p_hexdump IN VARCHAR2)
RETURN DATE
IS
l_date DATE;
BEGIN
DBMS_STATS.convert_raw_value(rawval => HEXTORAW(p_hexdump), resval => l_date);
RETURN l_date;
END get_date;
FUNCTION get_timestamp (p_hexdump IN VARCHAR2)
RETURN TIMESTAMP
IS
BEGIN
RETURN
TO_TIMESTAMP(
TO_CHAR(get_date(p_hexdump), 'YYYY-MM-DD"T"HH24:MI:SS')||
ROUND(TO_NUMBER(SUBSTR('&×tamp_as_hexdump.', LENGTH('&×tamp_as_hexdump.') - 7), 'XXXXXXXX')/POWER(10,9), 6),
'YYYY-MM-DD"T"HH24:MI:SS.FF6');
END get_timestamp;
SELECT get_date('&×tamp_as_hexdump.') AS time, get_timestamp('&×tamp_as_hexdump.') AS timestamp FROM DUAL
/
--