Conversion and casting functions
Conversion functions convert the expression or value from one data type to another type.
Converting data types
Functions prefixed with as(Type)
ensure that a value is of a target type. If the data type is incompatible, they return null
. These functions are applicable after parsing.
...| parse content, "LD'DQL 'KVP{LD:key'='(LONG:valueLong| BOOLEAN:valueBoolean| [!;]*:valueStr)';'?}:q"| fields timestamp, asLong(q[workTime])
The as*T
will try to cast the input to T
but won't perform any conversions, it will cause an exception for strongly typed fields (marked as ) and null for incompatible data types (empty cell).
asT(arg) => if(typeOf(arg) == ’T’, arg)
Integer
Integer
Long
Long
Double
Double
String
Boolean
Timestamp
Duration
Timeframe
Geopoint
IpAddress
Binary
Array
Record
V<Integer>
V<Integer>
V<Long>
V<Long>
V<Double>
V<Double>
V<String>
V<Boolean>
V<Timestamp>
V<Duration>
V<Timeframe>
V<Geopoint>
V<IpAddress>
V<SummaryStats>
V<Binary>
V<Array>
V<Record>
V<Record>
asArray
Returns array value if the value is array
, otherwise, returns null
.
Syntax
asArray(value)
Parameters
value
array
required
Returns
The data type of the returned value is array
.
Examples
Example 1
data record(a = array(2, 3, 7, 7, 1)),record(a = "DQL is awesome!"),record(a = 3.14)| fieldsAdd type(a), asArray(a)
Query result:
[2, 3, 7, 7, 1]
array
[2, 3, 7, 7, 1]
DQL is awesome!
string
3.14
double
asBinary
Returns binary value (byte array) if the value is binary
, otherwise, returns null
.
Syntax
asBinary(value)
Parameters
value
binary
required
Returns
The data type of the returned value is binary
.
Examples
Example 1
data record(a = 3.14),record(a = "dynatrace"),record(a = true),record(a = decodeBase64ToBinary("ZHluYXRyYWNl"))| fieldsAdd type(a), asBinary(a)
Query result:
3.14
double
dynatrace
string
true
boolean
ZHluYXRyYWNl
binary
ZHluYXRyYWNl
asBoolean
Returns boolean value if the value is boolean
, otherwise, returns null
.
Syntax
asBoolean(value)
Parameters
value
boolean
required
Returns
The data type of the returned value is boolean
.
Examples
Example 1
data record(a = true),record(a = "true"),record(a = 1)| fieldsAdd type(a), asBoolean(a)
Query result:
true
boolean
true
true
string
null
1
long
null
asDouble
Returns double
value if the value is double
, otherwise, returns null
.
Syntax
asDouble(value)
Parameters
value
double
required
Returns
The data type of the returned value is double
.
Examples
Example 1
data record(a = 3),record(a = 3.14),record(a = "3.14")| fieldsAdd type(a), asDouble(a)
Query result:
3
long
null
3.14
double
3.14
3.14
string
null
asDuration
Returns duration value if the value is duration
, otherwise, returns null
.
Syntax
asDuration(value)
Parameters
value
duration
required
Returns
The data type of the returned value is duration
.
Examples
Example 1
data record(a = 15s),record(a = 3.14),record(a = timeframe(from: "2019-08-01T09:30:00.000-0400", to: "2019-08-01T16:00:00.000-0400")),record(a = "42"),record(a = "42s")| fieldsAdd type(a), asDuration(a)
Query result:
15 s
duration
15 s
3.14
double
2019-08-01T13:30:00.000Z
end:
2019-08-01T20:00:00.000Z
timeframe
42
string
42s
string
asIp
You can use this function to cast to an IP address.
Syntax
asIp(expression)
Parameters
expression
string expression, ip address
The expression to cast an expression to an IP address.
required
Returns
The data type of the returned value is ip
.
Examples
Example 1
data record(a = ip("127.0.0.1")),record(a = "10.0.0.1")| fieldsAdd type(a), asIp(a)
Query result:
127.0.0.1
ip
127.0.0.1
10.0.0.1
string
null
asLong
Returns long
value if the value is long
, otherwise null
.
Syntax
asLong(value)
Parameters
value
long
required
Returns
The data type of the returned value is long
.
Examples
Example 1
data record(a = 3),record(a = 3.14),record(a = "3")| fieldsAdd type(a), asLong(a)
Query result:
3
long
3
3.14
double
null
3
string
null
asNumber
Returns the same value if the value is integer
, long
, double
, otherwise, returns null
.
Syntax
asNumber(value)
Parameters
value
double, long
required
Returns
The data type of the returned value is double
or long
.
Examples
Example 1
data record(a = 3),record(a = 3.14),record(a = "3.14")| fieldsAdd type(a), asNumber(a)
Query result:
3
long
3
3.14
double
3.14
3.14
string
null
asRecord
Returns record value if the value is record
, otherwise, returns null
.
Syntax
asRecord(value)
Parameters
value
record
required
Returns
The data type of the returned value is record
.
Examples
Example 1
data record(a = record(b = 3)),record(a = 3.14),record(a = "3"),record(a = array(2, 3, 7, 7, 1))| fieldsAdd type(a), asRecord(a)
Query result:
3
record
3
3.14
double
3
string
[2, 3, 7, 7, 1]
array
asString
Returns string value if the value is string
, otherwise, returns null
.
Syntax
asString(value)
Parameters
value
string
required
Returns
The data type of the returned value is string
.
Examples
Example 1
data record(a = array(1, 2, 3)),record(a = 3.14),record(a = "DQL is awesome!"),record(a = record(content = "A nested record"))| fieldsAdd type(a), asString(a)
Query result:
[1, 2, 3]
array
3.14
double
DQL is awesome!
string
DQL is awesome!
A nested record
record
asTimeframe
Returns timeframe
value if the value is timeframe
, otherwise returns null
.
Syntax
asTimeframe(value)
Parameters
value
timeframe
required
Returns
The data type of the returned value is timeframe
.
Examples
Example 1
data record(timeframe = timeframe(from: "2019-08-01T09:30:00.000-0400", to: "2019-08-01T16:00:00.000-0400")),record(timeframe = timeframe(from: - 24h, to: - 2h)),record(timeframe = "2019-08-01T15:30:00.000-0400/2019-08-01T22:00:00.000-0400")| fieldsAdd type(timeframe), asTimeframe(timeframe)
Query result:
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
timeframe
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
start: 2023-11-16T10:05:42.927Z
end: 2023-11-17T08:05:42.927Z
timeframe
start: 2023-11-16T10:05:42.927Z
end: 2023-11-17T08:05:42.927Z
2019-08-01T15:30:00.000-0400/2019-08-01T22:00:00.000-0400
string
null
asTimestamp
Returns timestamp
value if the value is timestamp
, otherwise, returns null
.
Syntax
asTimestamp(value)
Parameters
value
timestamp
required
Returns
The data type of the returned value is timestamp
.
Examples
Example 1
data record(timestamp = timestamp(2019, 8, 1, 13, 30, 0)),record(timestamp = 1564666200000000000),record(timestamp = "2019-08-01T09:30:00.000-0400")| fieldsAdd type(timestamp), asTimestamp(timestamp)
Query result:
2019-08-01T13:30:00.000Z
timestamp
2019-08-01T13:30:00.000Z
1,564,666,200,000,000,000
long
null
2019-08-01T09:30:00.000-0400
string
null
asUid
Returns a uid
value if the value is uid
, otherwise returns null
.
Syntax
asUid(value)
Parameters
value
uid
The value to cast.
required
Returns
The data type of the returned value is uid
.
Examples
Example 1
data record(a = uid64(123)), record(a = 123)| fields asUid(a)
Query result:
000000000000007b
null
decode
The decode function allows encoding binary data and strings into a string representation, and the opposite way. There are two types of decode functions, BASE64 and BASE16.
Syntax
decodeBase64ToBinary(expression)
decodeBase64ToString(expression)
decodeBase16ToBinary(expression)
decodeBase16ToString(expression)
Parameters
expression
string
An encoded string that needs to be decoded to a plain string or binary. Retrieves null
if the encoding format does not match the outcome format.
required
Returns
The data type of the returned value is binary
or string
.
Examples
Example 1
data record(content = "RFFMIGlzIGF3ZXNvbWUh"),record(content = "RHluYXRyYWNlIFF1ZXJ5IExhbmd1YWdl")| fieldsAdd decodeBase64ToString(content)
Query result:
RFFMIGlzIGF3ZXNvbWUh
DQL is awesome!
RHluYXRyYWNlIFF1ZXJ5IExhbmd1YWdl
Dynatrace Query Language
Example 2
data record(content = "44514c20697320617765736f6d6521"),record(content = "44796e617472616365205175657279204c616e6775616765")| fieldsAdd decodeBase16ToString(content)
Query result:
44514c20697320617765736f6d6521
DQL is awesome!
44796e617472616365205175657279204c616e6775616765
Dynatrace Query Language
encode
The encode function allows encoding binary data and strings into a string representation, and the opposite way. There are two types of encode functions, BASE64 and BASE16.
Syntax
encodeBase64(expression)
encodeBase16(expression)
Parameters
expression
string, binary
A string or binary expression to encode.
required
Returns
The data type of the returned value is string
.
Examples
Example 1
data record(content = "DQL is awesome!"),record(content = "Dynatrace Query Language")| fieldsAdd encodeBase16(content),encodeBase64(content)
Query result:
DQL is awesome!
44514c20697320617765736f6d6521
RFFMIGlzIGF3ZXNvbWUh
Dynatrace Query Language
44796e617472616365205175657279204c616e6775616765
RHluYXRyYWNlIFF1ZXJ5IExhbmd1YWdl
hexStringToNumber
Converts a hexadecimal string to a number.
Syntax
hexStringToNumber(expression)
Parameters
expression
string expression
The string expression that will be converted to a number.
required
Returns
The data type of the returned value is double
or long
.
Examples
Example 1
data record(a = "0x7f"),record(a = "100"),record(a = "0X80000000")| fieldsAdd hexStringToNumber(a)
Query result:
0x7f
127
100
256
0X80000000
2,147,483,648
numberToHexString
Converts a number to a hexadecimal string.
Syntax
numberToHexString(expression)
Parameters
expression
numeric expression
The numeric expression that will be converted to a hexadecimal string.
required
Returns
The data type of the returned value is string
.
Examples
Example 1
data record(a = 127),record(a = 256),record(a = 2147483648)| fieldsAdd numberToHexString(a)
Query result:
127
7f
256
100
2,147,483,648
80000000
toArray
Returns the value if it is an array
. Otherwise, converts a value to the single element array holding that value.
Syntax
toArray(value)
Parameters
value
array, boolean, double, duration, ip, long, record, string, timeframe, timestamp
required
Returns
The data type of the returned value is array
.
Examples
Example 1
data record(a = array(2, 3, 7, 7, 1)),record(a = "DQL is awesome!"),record(a = 3.14)| fieldsAdd type(a), toArray(a)
Query result:
[2, 3, 7, 7, 1]
array
[2, 3, 7, 7, 1]
DQL is awesome!
string
[DQL is awesome!]
3.14
double
[3.14]
toBoolean
Converts a value to Boolean if the value is of a suitable type. If the argument is an array, the element at position 0 is converted.
Use asBoolean(value)
function to return if the value is boolean
or variant<boolean>
, otherwise null
.
Converts string values true
or TRUE
to a Boolean true
.The comparison is case insensitive. Converts other values to Boolean false
. Converts numeric value 0 to Boolean false
. Converts other numeric values to Boolean true
.
Syntax
toBoolean(value)
Parameters
value
boolean, double, long, string, array
required
Returns
The data type of the returned value is boolean
.
Examples
Example 1
data record(a = true),record(a = "true"),record(a = "yes"),record(a = 0),record(a = 1),record(a = 2)| fieldsAdd type(a), toBoolean(a)
Query result:
true
boolean
true
true
string
true
yes
string
null
0
long
false
1
long
true
2
long
true
toDouble
Converts a value to double
if the value is of a suitable type. If the argument is an array
, the element at position 0 is converted.
Use asDouble(value)
function to return if the value is double
or variant<double>
, otherwise null
.
Syntax
toDouble(value)
Parameters
value
double, long, string, boolean, ip, timestamp, duration, array
required
Returns
The data type of the returned value is double
.
Examples
Example 1
data record(a = 3),record(a = 3.14),record(a = "3.14"),record(a = true),record(a = toTimestamp("2019-08-01T09:30:00.000-0400")),record(a = 15s),record(a = ip("10.0.0.1"))| fieldsAdd type(a), toDouble(a)
Query result:
3
long
3
3.14
double
3.14
3.14
string
3.14
true
boolean
1
2019-08-01T13:30:00.000Z
timestamp
1,564,666,200,000,000,000
15 s
duration
15,000,000,000
10.0.0.1
ip
167,772,161
toDuration
Converts a value to duration
if the value is of a suitable type. If the argument is an array
, the element at position 0 is converted.
Syntax
toDuration(value)
Parameters
value
duration, double, long, string, timeframe, array
required
Returns
The data type of the returned value is duration
.
Examples
Example 1
data record(a = 15s),record(a = 3.14),record(a = timeframe(from: "2019-08-01T09:30:00.000-0400", to: "2019-08-01T16:00:00.000-0400")),record(a = "42"),record(a = "42s")| fieldsAdd type(a), toDuration(a)
Query result:
15 s
duration
15 s
3.14
double
3 ns
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
timeframe
6.5 h
42
string
42 ns
42s
string
null
toIp
You can use this function to convert an expression to an IP address.
Syntax
toIp(expression)
Parameters
expression
string expression, ip address
The expression to convert an expression to an IP address.
required
Returns
The data type of the returned value is ip
.
Examples
Example 1
data record(a = ip("127.0.0.1")),record(a = "10.0.0.1"),record(a = "300.0.0.1"),record(a = 1234567890)| fieldsAdd type(a), toIp(a)
Query result:
127.0.0.1
ip
127.0.0.1
10.0.0.1
string
10.0.0.1
300.0.0.1
string
null
1,234,567,890
long
73.150.2.210
toLong
Converts a value to long
if the value is of a suitable type. If the argument is an array
, the element at position 0 is converted.
Syntax
toLong(value)
Parameters
value
long, double, string, boolean, ip, timestamp, duration, array
required
Returns
The data type of the returned value is long
.
Examples
Example 1
data record(a = 3),record(a = 3.14),record(a = "3"),record(a = true),record(a = false),record(a = ip("10.0.0.1")),record(a = 15s),record(a = toTimestamp("2019-08-01T09:30:00.000-0400"))| fieldsAdd type(a), toLong(a)
Query result:
3
long
3
3.14
double
3
3
string
3
true
boolean
1
false
boolean
0
10.0.0.1
ip
167,772,161
15 s
duration
15,000,000,000
2019-08-01T13:30:00.000Z
timestamp
1,564,666,200,000,000,000
toString
Returns the string representation of a value.
Syntax
toString(value)
Parameters
value
double, boolean, timestamp, timeframe, duration, ip, array, record
Parameter that should be transformed into text form.
required
Returns
The data type of the returned value is string
.
Examples
Example 1
data record(a = array(1, 2, 3)),record(a = true),record(a = 3),record(a = 3.14),record(a = 5m),record(a = toIp("127.0.0.1")),record(a = "DQL is awesome!"),record(a = timeframe(from: now() - 5m, to: now())),record(a = toTimestamp("2019-08-01T09:30:00.000-0400")),record(a = record(content = "A nested record"))| fieldsAdd type(a), toString(a)
Query result:
[1, 2, 3]
array
[1, 2, 3]
true
boolean
true
3
long
3
3.14
double
3.14
5 min
duration
"05:00.000000000"
127.0.0.1
ip
"127.0.0.1"
DQL is awesome!
string
DQL is awesome!
start: 2023-11-17T10:00:43.724Z
end: 2023-11-17T10:05:43.724Z
timeframe
"2023-11-17T10:00:43.724031180 +0000/2023-11-17T10:05:43.724031180 +0000"
2019-08-01T13:30:00.000Z
timestamp
"2019-08-01T13:30:00.000000000 +0000"
content: A nested record
record
{"content":"A nested record"}
toTimeframe
Converts a value to timeframe
if the value is of a suitable type. If the argument is an array
, the element at position 0 is converted.
Syntax
toTimeframe(value)
Parameters
value
timeframe, string, array
required
Returns
The data type of the returned value is timeframe
.
Examples
Example 1
data record(timeframe = timeframe(from: "2019-08-01T09:30:00.000-0400", to: "2019-08-01T16:00:00.000-0400")),record(timeframe = timeframe(from: - 24h, to: - 2h)),record(timeframe = "2019-08-01T09:30:00.000-0400/2019-08-01T16:00:00.000-0400")| fieldsAdd type(timeframe), toTimeframe(timeframe)
Query result:
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
timeframe
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
start: 2023-11-16T10:05:43.784Z
end: 2023-11-17T08:05:43.784Z
timeframe
start: 2023-11-16T10:05:43.784Z
end: 2023-11-17T08:05:43.784Z
2019-08-01T09:30:00.000-0400/2019-08-01T16:00:00.000-0400
string
start: 2019-08-01T13:30:00.000Z
end: 2019-08-01T20:00:00.000Z
toTimestamp
Converts a value to timestamp
if the value is of a suitable type. If the argument is an ARRAY, the element at position 0 is converted.
Use asTimestamp(<value>)
function to return if the value is timestamp
or variant<timestamp>
, otherwise null
.
Syntax
toTimestamp(value)
Parameters
value
timestamp, double, long , string, array
required
Returns
The data type of the returned value is timestamp
.
Examples
Example 1
data record(timestamp = toTimestamp("2019-08-01T09:30:00.000-0400")),record(timestamp = 1564666200000000000),record(timestamp = "2019-08-01T09:30:00.000-0400")| fieldsAdd type(timestamp), toTimestamp(timestamp)
Query result:
2019-08-01T13:30:00.000Z
timestamp
2019-08-01T13:30:00.000Z
1,564,666,200,000,000,000
long
2019-08-01T13:30:00.000Z
2019-08-01T09:30:00.000-0400
string
2019-08-01T13:30:00.000Z
toUid
Converts a value to uid
if the value is of a suitable type.
Syntax
toUid(value)
Parameters
value
number, string, uid, array
Any convertible value. If the argument is an array
, the element at position 0 is converted.
required
Returns
The data type of the returned value is uid
.
Examples
Example 1
data record(a = "550e8400-e29b-41d4-a716-446655440000", b = 123, c = uid64(456), d=array(123))| fields toUid(a), toUid(b), toUid(c), toUid(d)
Query result:
550e8400-e29b-41d4-a716-446655440000
000000000000007bt
00000000000001c8
000000000000007b
type
Returns the type of a value as a string
.
Syntax
type(expression)
Parameters
expression
array, boolean, double, duration, ip, long, record, string, timeframe, timestamp
required
Returns
The data type of the returned value is string
.
Examples
Example 1
data record(a = array(1, 2, 3)),record(a = true),record(a = 3),record(a = 3.14),record(a = 5m),record(a = toIp("127.0.0.1")),record(a = "DQL is awesome!"),record(a = timeframe(from: now() - 5m, to: now())),record(a = toTimestamp("2019-08-01T09:30:00.000-0400")),record(a = record(content = "A nested record"))| fieldsAdd type(a)
Query result:
[1, 2, 3]
array
true
boolean
3
long
3.14
double
5 min
duration
127.0.0.1
ip
DQL is awesome!
string
start: 2023-11-17T10:00:43.967Z
end: 2023-11-17T10:05:43.967Z
timeframe
2019-08-01T13:30:00.000Z
timestamp
content: A nested record
record
uid128
Creates a uid
from the given two long expressions.
Syntax
uid128(firstExpression, secondExpression)
Parameters
expression
long
The first long expression for a uid.
required
expression
long
The second long expression for a uid.
required
Returns
The data type of the returned value is uid
.
Examples
Example 1
data record(a = 123, b = 456)| fields uid128(a, b)
Query result:
000000000000007b00000000000001c8
uid64
Creates a uid
from the given long expression.
Syntax
uid64(expression)
Parameters
expression
long
The long expression for a uid.
required
Returns
The data type of the returned value is uid
.
Examples
Example 1
data record(a = 123)| fields uid64(a)
Query result:
000000000000007b