Analyze and visualize nested JSON data with Amazon Athena and Amazon QuickSight
Anoop Singh, Amazon Web Services
Summary
This pattern explains how to translate a nested, JSON-formatted data structure into a tabular view by using Amazon Athena, and then visualize the data in Amazon Quick Suite.
You can use JSON-formatted data for API-powered data feeds from operational systems to create data products. This data can also help you understand your customers and their interactions with your products better, so you can tailor user experiences and predict outcomes.
Prerequisites and limitations
Prerequisites
An active AWS account
A JSON file that represents a nested data structure (this pattern provides a sample file)
Limitations:
JSON features integrate well with existing SQL-oriented functions in Athena. However, they aren’t ANSI SQL compatible, and the JSON file is expected to carry each record on a separate line. You might need to use the
ignore.malformed.json
property in Athena to indicate if malformed JSON records should be turned into null characters or generate errors. For more information, see Best practices for reading JSON data in the Athena documentation.This pattern considers only simple and small amounts of JSON-formatted data. If you want to use these concepts at scale, consider applying data partitioning and consolidate your data into larger files.
Architecture
The following diagram shows the architecture and workflow for this pattern. The nested data structures are stored in Amazon Simple Storage Service (Amazon S3) in JSON format. In Athena, the JSON data is mapped to an Athena data structure. You then create a view to analyze the data, and visualize the data structure in Quick Suite.

Tools
AWS services
Amazon Simple Storage Service (Amazon S3) is a cloud-based object storage service that helps you store, protect, and retrieve any amount of data. This pattern uses Amazon S3 to store the JSON file.
Amazon Athena is an interactive query service that helps you analyze data directly in Amazon S3 by using standard SQL. This pattern uses Athena to query and transform the JSON data. With a few actions in the AWS Management Console, you can point Athena at your data in Amazon S3 and use standard SQL to run one-time queries. Athena is serverless, so there is no infrastructure to set up or manage, and you pay only for the queries that you run. Athena scales automatically and runs queries in parallel, so results are fast, even with large datasets and complex queries.
Amazon Quick Suite is a cloud-scale business intelligence (BI) service that helps you visualize, analyze, and report your data on a single dashboard. Quick Suite lets you easily create and publish interactive dashboards that include machine learning (ML) insights. You can access these dashboards from any device, and embed them into your applications, portals, and websites.
Example code
The following JSON file provides a nested data structure that you can use in this pattern.
{ "symbol": "AAPL", "financials": [ { "reportDate": "2017-03-31", "grossProfit": 20591000000, "costOfRevenue": 32305000000, "operatingRevenue": 52896000000, "totalRevenue": 52896000000, "operatingIncome": 14097000000, "netIncome": 11029000000, "researchAndDevelopment": 2776000000, "operatingExpense": 6494000000, "currentAssets": 101990000000, "totalAssets": 334532000000, "totalLiabilities": 200450000000, "currentCash": 15157000000, "currentDebt": 13991000000, "totalCash": 67101000000, "totalDebt": 98522000000, "shareholderEquity": 134082000000, "cashChange": -1214000000, "cashFlow": 12523000000, "operatingGainsLosses": null } ] }
Epics
Task | Description | Skills required |
---|---|---|
Create an S3 bucket. | To create a bucket to store the JSON file, sign in to the AWS Management Console, open the Amazon S3 console | Systems administrator |
Add the nested JSON data. | Upload your JSON file to the S3 bucket. For a sample JSON file, see the previous section. For instructions, see Uploading objects in the Amazon S3 documentation. | Systems administrator |
Task | Description | Skills required |
---|---|---|
Create a table for mapping the JSON data. |
For more information about creating tables, see the Athena documentation. | Developer |
Create a view for data analysis. |
For more information about creating views, see the Athena documentation. | Developer |
Analyze and validate the data. |
| Developer |
Task | Description | Skills required |
---|---|---|
Set up Athena as a data source in Quick Suite. |
| Systems administrator |
Visualize data in Quick Suite. |
| Data analyst |