创建 Athena 表时如何处理 json 文件中的文件名中的空格

问题描述

我的 Json 文件的字段名称中带有空格,例如“客户 ID”。json 文件位于 S3 存储桶中。因此,当我尝试在此 json 文件上创建 Athena 表时,它会引发我的错误,因为字段名称有空格。当加载时删除带有空格的字段时,它加载良好。我该如何处理这种情况,以便正确加载整个数据。

解决方法

如果您有机会将您的 json 文件转换为 csv

您可以尝试以下操作:

CREATE EXTERNAL TABLE IF NOT EXISTS db.table_name (
    .......
    `Customer_ID` int,   .......
ROW FORMAT SERDE 'org.apache.hadoop.hive.serde2.OpenCSVSerde'
WITH SERDEPROPERTIES (
    'separatorChar' = ',','quoteChar' = '\"',   
    'escapeChar' = '\\' ) 
STORED AS TEXTFILE LOCATION 's3://location'
TBLPROPERTIES ('skip.header.line.count'='1')

主要思想是 - TBLPROPERTIES ('skip.header.line.count'='1')在这里您跳过 .csv 文件中的标题并设置您的自定义列名称强>