Amazon web services 无法在AWS Athena中查询视图

Amazon web services 无法在AWS Athena中查询视图,amazon-web-services,presto,amazon-athena,Amazon Web Services,Presto,Amazon Athena,我试图在AWS Athena中创建一个简单视图,然后查询该视图。初始查询运行良好,并返回结果。然后,我单击“从查询创建视图”,它运行以下操作,这也是成功的: CREATE OR REPLACE VIEW "ios_events" AS SELECT * FROM my_db WHERE context.device.type = 'ios'; 但是,我根本无法查询这个创建的视图。它显示在UI中,但即使我在UI中单击视图的“预览”并运行: SELECT * FROM "my_db"."ios_e

我试图在AWS Athena中创建一个简单视图,然后查询该视图。初始查询运行良好,并返回结果。然后,我单击“从查询创建视图”,它运行以下操作,这也是成功的:

CREATE OR REPLACE VIEW "ios_events" AS
SELECT *
FROM my_db
WHERE context.device.type = 'ios';
但是,我根本无法查询这个创建的视图。它显示在UI中,但即使我在UI中单击视图的“预览”并运行:

SELECT * FROM "my_db"."ios_events" limit 10;
这将导致一个大错误,以
通用\u内部\u错误开始:无法从JSON响应创建com.facebook.presto.execution.TaskInfo类:
。在错误的后面,它有以下内容:

...

java.lang.Thread.run(Thread.java:748) Caused by:
com.fasterxml.jackson.databind.JsonMappingException:
line 1:143: extraneous input 'from' expecting
{'ADD', 'ALL', 'SOME', 'ANY', 'AT', 'NO', 'SUBSTRING', 'POSITION', 'TINYINT', 'SMALLINT', 'INTEGER', 'DATE', 'TIME', 'TIMESTAMP', 'INTERVAL', 'YEAR', 'MONTH', 'DAY', 'HOUR', 'MINUTE', 'SECOND', 'ZONE', 'FILTER', 'OVER', 'PARTITION', 'RANGE', 'ROWS', 'PRECEDING', 'FOLLOWING', 'CURRENT', 'ROW', 'SCHEMA', 'COMMENT', 'VIEW', 'REPLACE', 'GRANT', 'REVOKE', 'PRIVILEGES', 'PUBLIC', 'OPTION', 'EXPLAIN', 'ANALYZE', 'FORMAT', 'TYPE', 'TEXT', 'GRAPHVIZ', 'LOGICAL', 'DISTRIBUTED', 'VALIDATE', 'SHOW', 'TABLES', 'VIEWS', 'SCHEMAS', 'CATALOGS', 'COLUMNS', 'COLUMN', 'USE', 'PARTITIONS', 'FUNCTIONS', 'TO', 'SYSTEM', 'BERNOULLI', 'POISSONIZED', 'TABLESAMPLE', 'ARRAY', 'MAP', 'SET', 'RESET', 'SESSION', 'DATA', 'START', 'TRANSACTION', 'COMMIT', 'ROLLBACK', 'WORK', 'ISOLATION', 'LEVEL', 'SERIALIZABLE', 'REPEATABLE', 'COMMITTED', 'UNCOMMITTED', 'READ', 'WRITE', 'ONLY', 'CALL', 'INPUT', 'OUTPUT', 'CASCADE', 'RESTRICT', 'INCLUDING', 'EXCLUDING', 'PROPERTIES', 'FUNCTION', 'LAMBDA_INVOKE', 'RETURNS', 'SAGEMAKER_INVOKE_ENDPOINT', 'NFD', 'NFC', 'NFKD', 'NFKC', 'IF', 'NULLIF', 'COALESCE', IDENTIFIER, DIGIT_IDENTIFIER, QUOTED_IDENTIFIER, BACKQUOTED_IDENTIFIER}
(through reference chain: com.facebook.presto.server.TaskUpdateRequest["fragment"]
->com.facebook.presto.sql.planner.PlanFragment["root"]
->com.facebook.presto.sql.planner.plan.OutputNode["source"]
->com.facebook.presto.sql.planner.plan.ProjectNode["assignments"]
->com.facebook.presto.sql.planner.plan.Assignments["assignments"]
->java.util.LinkedHashMap["expr_89"]) at

...

这似乎意味着查询的结构不正确。但这只是一个超级简单的选择,由AWS Athena UI本身生成。我遗漏了什么?

你能试试从ios\u事件限制10中选择*吗?(没有
“我的数据库”。
)什么是
上下文.device.type
?这是在查询JSON数据吗?Select语句是否独立工作(
Select*FROM my_db WHERE context.device.type='ios';
)?