根据日期类型的字段过滤 Flink 表



我创建了一个表,其中包含一个类型为 Date 的字段,即 f_date。我想要的查询的一部分根据f_date字段过滤表行。所以我做了以下工作:

mytable.filter("f_date <= '1998-10-02'")

mytable.filter("f_date <= '1998/10/02'")

然后我在所有两种情况下都遇到了以下相同的错误:

Expression 'f_date <= 1998/10/02 failed on input check: Comparison is only supported for numeric types and comparable types of the same type, got Date and String

我什至删除了单个四分法并尝试:

mytable.filter("f_date <= 1998/10/02")

我得到了错误:

Expression 'f_date <= ((1998 / 10) / 2) failed on input check: Comparison is only supported for numeric types and comparable types of same type, got Date and Integer

最后,我创建一个 Date 对象并尝试:

mytable.filter("f_date <=" + Java.sql.Date.valueOf("1998-10-22"))

我得到了错误:

Expression 'f_date <= ((1998 - 10) - 2) failed on input check: Comparison is only supported for numeric types and comparable types of the same type, got Date and Integer

在上述情况下,Flink 将日期识别为 String 或 Integer。我怎样才能以正确的格式给出日期!?

我应该使用 toDate 方法将字符串转换为日期

filter("f_date <= '1998-10-02'.toDate")

相关内容

  • 没有找到相关文章

最新更新