首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从BSON文件创建配置单元表时列值变为NULL

从BSON文件创建配置单元表时列值变为NULL
EN

Stack Overflow用户
提问于 2019-05-29 12:46:44
回答 1查看 126关注 0票数 0

我从MongoDB (4.0).After的BSON文件转储创建了一个蜂窝(3.1.2)表。创建该表时,我从表中选择了几个条目。但是,它们中的一些值为空。

我尝试使用python打印来自BSON的表行。它打印的值是正确的。表示没有丢失的值。有关于如何进一步解决问题的线索吗?

用于创建配置单元表的SQL。

代码语言:javascript
复制
CREATE EXTERNAL TABLE `tmp_test_status`(
  `id` string COMMENT 'frame_id', 
  `createdAt` INT, 
  `updatedAt` string, 
  `task` string)
row format serde 'com.mongodb.hadoop.hive.BSONSerDe'
with serdeproperties('mongo.columns.mapping'='{"id":"_id"}')
stored as inputformat         'com.mongodb.hadoop.mapred.BSONFileInputFormat'
outputformat 'com.mongodb.hadoop.hive.output.HiveBSONFileOutputFormat'
LOCATION
  'oss://data-warehouse/hive/warehouse/data.db/tmp_test_status';

===

我用python bson lib打印的数据。

代码语言:javascript
复制
{'_id': '00003a02-280d-4e59-8483-a0143e0a3359', 'createdAt': '1557999191951', 'updatedAt': '1557999191951', 'task': 'lane', '__v': 0}

===

我从Hive表中选择的数据:

代码语言:javascript
复制
00003a02-280d-4e59-8483-a0143e0a3359    NULL    NULL    lane
093e72ae-206b-4112-ac28-5ba38f9485d0    NULL    NULL    lane
093ebe41-183c-47b4-ab25-93336875ae10    NULL    NULL    lane
093ec16b-ba1d-4ddc-90bc-9981342e8071    NULL    NULL    lane
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-11 02:39:38

我自己找到了答案,原因是BSON文件属性名区分大小写,而Hive不区分大小写。如果属性名称在BSON文件中包含大写,那么当query.Simply通过我工作的表属性映射属性名称时,配置单元将返回NULL。

代码语言:javascript
复制
with serdeproperties('mongo.columns.mapping'='{"id":"_id", "createdAt": "createdAt", "updatedAt": "updatedAt", "reLabeled1" : "reLabeled1", "isValid": "isValid"}')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56353262

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档