1

我使用 sqoop 将带有选定列的表导入到 avro 文件格式。使用 avro-tools tojson 日期以奇怪的格式出现(负数)。我怎样才能解码日期?

    {"first_name":{"string":"Mary"},"last_name":  {"string":"Botman"},"birth_date":{"long":-345772800000}}

MySQL 查询的正确格式在哪里

  mysql> select first_name, last_name, birth_date from employees where first_name like 'Mary' and last_name ='Botman';
  +------------+-----------+------------+
  | first_name | last_name | birth_date |
  +------------+-----------+------------+
  | Mary       | Botman    | 1959-01-17 |
  +------------+-----------+------------+
  1 row in set (0.07 sec)
4

1 回答 1

1

长值 -345772800000 代表...

...自称为“纪元”的标准基准时间以来的指定毫秒数,即 1970 年 1 月 1 日,格林威治标准时间 00:00:00 自 1970 年 1 月 1 日以来的毫秒数

在您的示例中,它是一个负值,因此它从“时代”开始倒计时。LocalDate在 Java 代码中,您可以按如下方式从此值创建一个,这将为您提供与 Hive 查询结果中显示的相同的结果。

LocalDate date17Jan1959 = Instant.ofEpochMilli(-345772800000L)
    .atZone(ZoneOffset.UTC)
    .toLocalDate();
于 2018-02-13T18:22:24.393 回答