-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUTL$XML.package_body.sql
103 lines (83 loc) · 2.78 KB
/
UTL$XML.package_body.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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
CREATE OR REPLACE
PACKAGE BODY UTL$XML
IS
/**
* ============================================================================
* History of changes
* ============================================================================
* Date (DD/MM/YYYY) Who Description
* ----------------- ----------------- --------------------------------
* 11/06/2012 Martin Mareš GitHub distribution
* ============================================================================
*/
FUNCTION get_xsd_date_time(date_in IN DATE
,with_time_zone_in IN BOOLEAN DEFAULT FALSE) RETURN VARCHAR2
IS
BEGIN
RETURN
CASE
WHEN date_in IS NOT NULL
THEN TO_CHAR(date_in, 'YYYY-MM-DD') ||
'T' ||
TO_CHAR(date_in, 'HH24:MI:SS') ||
CASE
WHEN with_time_zone_in
THEN '.0Z'
ELSE NULL
END
ELSE NULL
END;
END get_xsd_date_time;
FUNCTION get_xsd_date_time(date_in IN DATE
,with_time_zone_in IN VARCHAR2) RETURN VARCHAR2
IS
BEGIN
IF (with_time_zone_in IN('A', 'Y')) THEN
RETURN get_xsd_date_time(date_in, true);
ELSE
RETURN get_xsd_date_time(date_in, false);
END IF;
END get_xsd_date_time;
FUNCTION get_xsd_date_time_long(date_in IN DATE) RETURN VARCHAR2
IS
BEGIN
RETURN
CASE
WHEN date_in IS NOT NULL
THEN TO_CHAR(date_in, 'YYYY-MM-DD') ||
'T' ||
TO_CHAR(date_in, 'HH24:MI:SS') ||
'.000+01:00'
ELSE NULL
END;
END get_xsd_date_time_long;
FUNCTION escape_xml_chars(text_in IN VARCHAR2) RETURN VARCHAR2
IS
BEGIN
RETURN REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(text_in, '&', '&'), '>', '>'), '<', '<'), '''', '''), '"', '"');
END escape_xml_chars;
FUNCTION unescape_xml_chars(text_in IN VARCHAR2) RETURN VARCHAR2
IS
BEGIN
RETURN REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(text_in, '&', '&'), '>', '>'), '<', '<'), ''', ''''), '"', '"');
END unescape_xml_chars;
FUNCTION get_cdata_begin RETURN VARCHAR2
IS
BEGIN
RETURN '<![CDATA[';
END get_cdata_begin;
FUNCTION get_cdata_end RETURN VARCHAR2
IS
BEGIN
RETURN ']]>';
END get_cdata_end;
FUNCTION fix_xsd_double(number_in IN NUMBER) RETURN VARCHAR2
IS
l_str VARCHAR2(2000);
BEGIN
l_str := number_in;
l_str := REPLACE(l_str, ',', '.');
RETURN l_str;
END fix_xsd_double;
END UTL$XML;
/