Converting and Casting Types
SQream supports explicit and implicit casting and type conversion. The system may automatically add implicit casts when combining different data types in the same expression. In many cases, while the details related to this are not important, they can affect the results of a query. When necessary, an explicit cast can be used to override the automatic cast added by SQream DB.
For example, the ANSI standard defines a SUM()
aggregation over an INT
column as an INT
. However, when dealing with large amounts of data this could cause an overflow.
You can rectify this by casting the value to a larger data type, as shown below:
SUM(some_int_column :: BIGINT)
SQream supports the following three data conversion types:
CAST(<value> AS <data type>)
, to convert a value from one type to another. For example,CAST('1997-01-01' AS DATE)
,CAST(3.45 AS SMALLINT)
,CAST(some_column AS TEXT)
.<value> :: <data type>
, a shorthand for theCAST
syntax. For example,'1997-01-01' :: DATE
,3.45 :: SMALLINT
,(3+5) :: BIGINT
.See the SQL functions reference for additional functions that convert from a specific value which is not an SQL type, such as FROM_UNIXTS, FROM_UNIXTSMS, etc.
Supported Casts
BOOL |
TINYINT/SMALLINT/INT/BIGINT |
REAL/FLOAT |
NUMERIC |
DATE/DATETIME |
VARCHAR/TEXT |
|
---|---|---|---|---|---|---|
BOOL |
N/A |
✓ |
✗ |
✗ |
✗ |
✓ |
TINYINT/SMALLINT/INT/BIGINT |
✓ |
N/A |
✓ |
✓ |
✗ |
✓ |
REAL/FLOAT |
✗ |
✓ |
N/A |
✓ |
✗ |
✓ |
NUMERIC |
✗ |
✓ |
✓ |
✓ |
✗ |
✓ |
DATE/DATETIME |
✗ |
✗ |
✗ |
✗ |
N/A |
✓ |
VARCHAR/TEXT |
✓ |
✓ |
✓ |
✓ |
✓ |
N/A |