)]}'
{
  "commit": "b23bd7a26e1df3e2b08cdb03a86e42fe267c2fd6",
  "tree": "30193b0d972add73653dee0606b8358196316d65",
  "parents": [
    "9dba51d7c88e3bdff33a1f4d800ef16dcea8885c"
  ],
  "author": {
    "name": "Andrew Lamb",
    "email": "andrew@nerdnetworks.org",
    "time": "Fri Aug 15 03:44:04 2025 -0700"
  },
  "committer": {
    "name": "GitHub",
    "email": "noreply@github.com",
    "time": "Fri Aug 15 06:44:04 2025 -0400"
  },
  "message": "[BLOG] Using External Indexes, Metadata Stores, Catalogs and Caches to Accelerate Queries on Apache Parquet (#99)\n\n* [BLOG] Using External Indexes and Metadata Stores to Accelerate Queries on Apache Parquet\n\n* Apply suggestions from code review\n\n* Fix headings\n\n* Hone background section\n\n* fix link\n\n* Update content/blog/2025-08-15-external-parquet-indexes.md\n\nCo-authored-by: Adam Reeve \u003cadreeve@gmail.com\u003e\n\n* strengthen first paragraph of background\n\n* wordsmith\n\n* grammar\n\n* improved ascii art\n\n* more grammar\n\n* paren\n\n* pages --\u003e files in diagram\n\n* grammar\n\n* Implement @comphead\u0027s suggestion: highlighted the benefit of external indexes comparing to file level indexes in terms of IO\n\n* honing\n\n* capitalization OCD\n\n* Add acnknoeldgements section\n\n---------\n\nCo-authored-by: Adam Reeve \u003cadreeve@gmail.com\u003e",
  "tree_diff": [
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "62d4cfed98e6b6f07828a618a65dea9215e2db20",
      "new_mode": 33188,
      "new_path": "content/blog/2025-08-15-external-parquet-indexes.md"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "8906c8aff1e9b308174d66bbd39687cc913acbf5",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/external-index-overview.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "de408bf6e5087b2724f794046a478cbe3c6438b6",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/parquet-filter-pushdown.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "cf23b62003ab33f77bb49d551f4094e6f1f95462",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/parquet-layout.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "12c81d196128c36f8da13597b4a545079d4bf34f",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/parquet-metadata.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "64e91b9b048d459f3cff4318d235ee7cd67b477c",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/processing-pipeline.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "ba0da7ec7cd0e61a200ba2054f89af5cdac4ac27",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/prune-files.png"
    },
    {
      "type": "add",
      "old_id": "0000000000000000000000000000000000000000",
      "old_mode": 0,
      "old_path": "/dev/null",
      "new_id": "4f5d48e8eacbdef2169746b24aa3f3f526ae5cea",
      "new_mode": 33188,
      "new_path": "content/images/external-parquet-indexes/prune-row-groups.png"
    }
  ]
}
