Data types

Data types define how values are stored and processed in a database. They determine what kind of data can be stored in a column (like numbers, text, dates, etc.), how much storage space the data will use, and what operations can be performed on the values. Choosing the right data type is important for both data integrity and query performance.

Each column in a table must have a specified data type that matches the kind of data you plan to store. For example, you would use numeric types for calculations, string types for text, and date/time types for temporal data.

The following data types are supported at ingest:

  • Int8, Int16, Int32, Int64, Int128, Int256
  • UInt8, UInt16, UInt32, UInt64, UInt128, UInt256
  • Float32, Float64
  • Decimal, Decimal(P, S), Decimal32(S), Decimal64(S), Decimal128(S), Decimal256(S)
  • String
  • FixedString(N)
  • UUID
  • Date, Date32
  • DateTime([TZ]), DateTime64(P, [TZ])
  • Bool
  • Array(T)
  • Map(K, V)
  • LowCardinality
  • Nullable
  • JSON

If you are ingesting using the NDJSON format and would like to store Decimal values containing 15 or more digits, send the values as string instead of numbers to avoid precision issues. In the following example, the first value has a high chance of losing accuracy during ingestion, while the second one is stored correctly:

{"decimal_value": 1234567890.123456789}  # Last digits might change during ingestion
{"decimal_value": "1234567890.123456789"}  # Will be stored correctly

The JSON data type is in private beta. If you are interested in using this type, contact Tinybird at support@tinybird.co or in the Community Slack.