文档文档

将值强制转换为不同的类型

使用 CAST 函数或双冒号 :: 强制转换简写语法将值强制转换为特定类型。

-- CAST function
SELECT CAST(1234.5 AS BIGINT)

-- Double-colon casting shorthand
SELECT 1234.5::BIGINT

强制转换操作可以在列表达式或字面量值上执行。例如,以下查询使用入门示例数据,并且

  • time 列中的所有值强制转换为整数(Unix 纳秒时间戳)。
  • 为每行将字面量字符串值 '1234' 强制转换为 64 位浮点数。
SELECT
  time::BIGINT AS unix_time,
  '1234'::DOUBLE AS string_to_float
FROM home
LIMIT 5
SELECT
  CAST(time AS BIGINT) AS unix_time,
  CAST('1234' AS DOUBLE) AS string_to_float
FROM home
LIMIT 5
unix_timestring_to_float
16410240000000000001234
16410276000000000001234
16410312000000000001234
16410348000000000001234
16410384000000000001234

强制转换为字符串类型

在强制转换操作中使用 STRINGCHARVARCHARTEXT 类型将值强制转换为字符串。

value::STRING
value::CHAR
value::VARCHAR
value::TEXT
CAST(value AS STRING)
CAST(value AS CHAR)
CAST(value AS VARCHAR)
CAST(value AS TEXT)

SQL 支持将以下类型强制转换为字符串值

  • 浮点数
  • 整数
  • 无符号整数
  • 布尔值
  • 时间戳

强制转换为数字类型

InfluxDB SQL 实现支持 64 位浮点数 (DOUBLE)、整数 (BIGINT) 和无符号整数 (BIGINT UNSIGNED)。

强制转换为浮点数

在强制转换操作中使用 DOUBLE 类型将值强制转换为 64 位浮点数。

value::DOUBLE
CAST(value AS DOUBLE)

SQL 支持将以下类型强制转换为浮点数值

  • 字符串:返回数字字符串 ([0-9]) 的浮点数等效值。还支持以下字符串模式

    • 科学计数法 ('123.4E+10')
    • 无穷大 ('±Inf')
    • NaN ('NaN')
  • 整数

  • 无符号整数

强制转换为整数

在强制转换操作中使用 BIGINT 类型将值强制转换为 64 位有符号整数。

value::BIGINT
CAST(value AS BIGINT)

SQL 支持将以下类型强制转换为整数

  • 字符串:返回数字字符串 ([0-9]) 的整数等效值。
  • 浮点数:截断小数点后的浮点数值。
  • 无符号整数:返回无符号整数的有符号整数等效值。
  • 布尔值true 返回 1false 返回 0
  • 时间戳:返回等效的 纳秒纪元时间戳

强制转换为无符号整数

在强制转换操作中使用 BIGINT UNSIGNED 类型将值强制转换为 64 位无符号整数。

value::BIGINT UNSIGNED
CAST(value AS BIGINT UNSIGNED)

SQL 支持将以下类型强制转换为无符号整数

  • 字符串:返回数字字符串 ([0-9]) 的无符号整数等效值。
  • 浮点数:截断小数点后的浮点数值。
  • 整数:返回有符号整数的无符号整数等效值。
  • 布尔值true 返回 1false 返回 0
  • 时间戳:返回等效的 纳秒纪元时间戳

强制转换为布尔类型

在强制转换操作中使用 BOOLEAN 类型将值强制转换为布尔值。

value::BOOLEAN
CAST(value AS BOOLEAN)

SQL 支持将以下类型强制转换为布尔值

  • 字符串
    • 返回 true
      • 'true' (不区分大小写)
      • 't'(不区分大小写)
      • '1'
    • 返回 false
      • 'false' (不区分大小写)
      • 'f' (不区分大小写)
      • '0'
  • 整数
    • 返回 true:正非零整数
    • 返回 false0
  • 无符号整数
    • 返回 true:非零无符号整数
    • 返回 false0

强制转换为时间戳类型

在强制转换操作中使用 TIMESTAMP 类型将值强制转换为时间戳。

value::TIMESTAMP
CAST(value AS TIMESTAMP)

SQL 支持将以下类型强制转换为时间戳

  • 字符串:返回字符串值的时间戳等效值。支持以下 RFC3339 和类 RFC3339 字符串模式

    • YYYY-MM-DDT00:00:00.000Z
    • YYYY-MM-DDT00:00:00.000-00:00
    • YYYY-MM-DD 00:00:00.000-00:00
    • YYYY-MM-DDT00:00:00Z
    • YYYY-MM-DD 00:00:00.000
    • YYYY-MM-DD 00:00:00
    • YYYY-MM-DD
  • 整数:将整数解析为 Unix 时间戳,并返回等效的时间戳。

  • 无符号整数:将无符号整数解析为 Unix 纳秒时间戳,并返回等效的时间戳。

将 Unix 纳秒时间戳强制转换为时间戳类型

要将 Unix 纳秒时间戳强制转换为时间戳类型,请首先将数值强制转换为无符号整数 (BIGINT UNSIGNED),然后再强制转换为时间戳。您还可以使用 to_timestamp_nanos 函数。

1704067200000000000::BIGINT UNSIGNED::TIMESTAMP
CAST(CAST(1704067200000000000 AS BIGINT UNSIGNED) AS TIMESTAMP)
to_timestamp_nanos(1704067200000000000)

时间戳函数

您还可以使用以下 SQL 函数将值强制转换为时间戳类型


此页内容是否对您有帮助?

感谢您的反馈!


Flux 的未来

Flux 即将进入维护模式。您可以继续像现在一样使用它,而无需对代码进行任何更改。

阅读更多

InfluxDB 3 开源版本现已发布公开 Alpha 版

InfluxDB 3 开源版本现已可用于 Alpha 测试,根据 MIT 或 Apache 2 许可获得许可。

我们正在发布两个产品作为 Alpha 版的一部分。

InfluxDB 3 Core 是我们新的开源产品。它是用于时间序列和事件数据的最新数据引擎。InfluxDB 3 Enterprise 是一个商业版本,它建立在 Core 的基础上,增加了历史查询能力、读取副本、高可用性、可扩展性和细粒度的安全性。

有关如何开始使用的更多信息,请查看