blob: 3714d0a033f8241378d96413ba20e23a8af7f96f [file] [log] [blame]
<!doctype html>
<html lang="en" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<link rel="prev" href="../docs/1.4.0/delta-lake-migration/">
<link rel="next" href="../roadmap/">
<link rel="icon" href="../assets/images/favicon-96x96.png">
<meta name="generator" content="mkdocs-1.5.3, mkdocs-material-9.5.3">
<title>Releases - Apache Iceberg</title>
<link rel="stylesheet" href="../assets/stylesheets/main.50c56a3b.min.css">
<link rel="stylesheet" href="../assets/stylesheets/palette.06af60db.min.css">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Nunito+Sans:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
<style>:root{--md-text-font:"Nunito Sans";--md-code-font:"Roboto Mono"}</style>
<link rel="stylesheet" href="../assets/stylesheets/extra.css">
<link rel="stylesheet" href="../assets/stylesheets/bootstrap-grid.css">
<link rel="stylesheet" href="../assets/stylesheets/bootstrap-buttons.css">
<link rel="stylesheet" href="../assets/stylesheets/home.css">
<script>__md_scope=new URL("..",location),__md_hash=e=>[...e].reduce((e,_)=>(e<<5)-e+_.charCodeAt(0),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
</head>
<body dir="ltr" data-md-color-scheme="iceberg" data-md-color-primary="indigo" data-md-color-accent="indigo">
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
<label class="md-overlay" for="__drawer"></label>
<div data-md-component="skip">
<a href="#downloads" class="md-skip">
Skip to content
</a>
</div>
<div data-md-component="announce">
</div>
<!--
Copyright (c) 2016-2023 Martin Donath <martin.donath@squidfunk.com>
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to
deal in the Software without restriction, including without limitation the
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
sell copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
IN THE SOFTWARE.
-->
<!-- Determine classes -->
<!-- Header -->
<header class="md-header md-header--shadow md-header--lifted" data-md-component="header">
<nav class="md-header__inner md-grid" aria-label="Header">
<!-- Link to home -->
<a
href=".."
title="Apache Iceberg"
class="md-header__button md-logo"
aria-label="Apache Iceberg"
data-md-component="logo"
>
<img src="../assets/images/Iceberg-logo.svg" alt="logo">
</a>
<!-- Button to open drawer -->
<label class="md-header__button md-icon" for="__drawer">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
</label>
<!-- Header title -->
<div class="md-header__title" data-md-component="header-title">
<div class="md-header__ellipsis">
<div class="md-header__topic">
<span class="md-ellipsis"> </span>
</div>
<div class="md-header__topic" data-md-component="header-topic">
<span class="md-ellipsis">
Releases
</span>
</div>
</div>
</div>
<!-- Button to open search modal -->
<label class="md-header__button md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg>
</label>
<!-- Search interface -->
<div class="md-search" data-md-component="search" role="dialog">
<label class="md-search__overlay" for="__search"></label>
<div class="md-search__inner" role="search">
<form class="md-search__form" name="search">
<input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
<label class="md-search__icon md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12Z"/></svg>
</label>
<nav class="md-search__options" aria-label="Search">
<button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41Z"/></svg>
</button>
</nav>
<div class="md-search__suggest" data-md-component="search-suggest"></div>
</form>
<div class="md-search__output">
<div class="md-search__scrollwrap" data-md-scrollfix>
<div class="md-search-result" data-md-component="search-result">
<div class="md-search-result__meta">
Initializing search
</div>
<ol class="md-search-result__list" role="presentation"></ol>
</div>
</div>
</div>
</div>
</div>
<div class="md-social">
<a href="https://iceberg.apache.org/community/" target="_blank" rel="noopener" title="iceberg.apache.org" class="md-social__link">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 640 512"><!--! Font Awesome Free 6.5.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><path d="M88.2 309.1c9.8-18.3 6.8-40.8-7.5-55.8C59.4 230.9 48 204 48 176c0-63.5 63.8-128 160-128s160 64.5 160 128-63.8 128-160 128c-13.1 0-25.8-1.3-37.8-3.6-10.4-2-21.2-.6-30.7 4.2-4.1 2.1-8.3 4.1-12.6 6-16 7.2-32.9 13.5-49.9 18 2.8-4.6 5.4-9.1 7.9-13.6 1.1-1.9 2.2-3.9 3.2-5.9zM0 176c0 41.8 17.2 80.1 45.9 110.3-.9 1.7-1.9 3.5-2.8 5.1-10.3 18.4-22.3 36.5-36.6 52.1-6.6 7-8.3 17.2-4.6 25.9C5.8 378.3 14.4 384 24 384c43 0 86.5-13.3 122.7-29.7 4.8-2.2 9.6-4.5 14.2-6.8 15.1 3 30.9 4.5 47.1 4.5 114.9 0 208-78.8 208-176S322.9 0 208 0 0 78.8 0 176zm432 304c16.2 0 31.9-1.6 47.1-4.5 4.6 2.3 9.4 4.6 14.2 6.8C529.5 498.7 573 512 616 512c9.6 0 18.2-5.7 22-14.5 3.8-8.8 2-19-4.6-25.9-14.2-15.6-26.2-33.7-36.6-52.1-.9-1.7-1.9-3.4-2.8-5.1 28.8-30.3 46-68.6 46-110.4 0-94.4-87.9-171.5-198.2-175.8 4.1 15.2 6.2 31.2 6.2 47.8v.6c87.2 6.7 144 67.5 144 127.4 0 28-11.4 54.9-32.7 77.2-14.3 15-17.3 37.6-7.5 55.8 1.1 2 2.2 4 3.2 5.9 2.5 4.5 5.2 9 7.9 13.6-17-4.5-33.9-10.7-49.9-18-4.3-1.9-8.5-3.9-12.6-6-9.5-4.8-20.3-6.2-30.7-4.2-12.1 2.4-24.7 3.6-37.8 3.6-61.7 0-110-26.5-136.8-62.3-16 5.4-32.8 9.4-50 11.8C279 439.8 350 480 432 480z"/></svg>
</a>
<a href="https://github.com/apache/iceberg" target="_blank" rel="noopener" title="github.com" class="md-social__link">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><!--! Font Awesome Free 6.5.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><path d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z"/></svg>
</a>
<a href="https://www.youtube.com/@ApacheIceberg" target="_blank" rel="noopener" title="www.youtube.com" class="md-social__link">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 576 512"><!--! Font Awesome Free 6.5.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><path d="M549.655 124.083c-6.281-23.65-24.787-42.276-48.284-48.597C458.781 64 288 64 288 64S117.22 64 74.629 75.486c-23.497 6.322-42.003 24.947-48.284 48.597-11.412 42.867-11.412 132.305-11.412 132.305s0 89.438 11.412 132.305c6.281 23.65 24.787 41.5 48.284 47.821C117.22 448 288 448 288 448s170.78 0 213.371-11.486c23.497-6.321 42.003-24.171 48.284-47.821 11.412-42.867 11.412-132.305 11.412-132.305s0-89.438-11.412-132.305zm-317.51 213.508V175.185l142.739 81.205-142.739 81.201z"/></svg>
</a>
<a href="https://join.slack.com/t/apache-iceberg/shared_invite/zt-287g3akar-K9Oe_En5j1UL7Y_Ikpai3A" target="_blank" rel="noopener" title="join.slack.com" class="md-social__link">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.5.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><path d="M94.12 315.1c0 25.9-21.16 47.06-47.06 47.06S0 341 0 315.1c0-25.9 21.16-47.06 47.06-47.06h47.06v47.06zm23.72 0c0-25.9 21.16-47.06 47.06-47.06s47.06 21.16 47.06 47.06v117.84c0 25.9-21.16 47.06-47.06 47.06s-47.06-21.16-47.06-47.06V315.1zm47.06-188.98c-25.9 0-47.06-21.16-47.06-47.06S139 32 164.9 32s47.06 21.16 47.06 47.06v47.06H164.9zm0 23.72c25.9 0 47.06 21.16 47.06 47.06s-21.16 47.06-47.06 47.06H47.06C21.16 243.96 0 222.8 0 196.9s21.16-47.06 47.06-47.06H164.9zm188.98 47.06c0-25.9 21.16-47.06 47.06-47.06 25.9 0 47.06 21.16 47.06 47.06s-21.16 47.06-47.06 47.06h-47.06V196.9zm-23.72 0c0 25.9-21.16 47.06-47.06 47.06-25.9 0-47.06-21.16-47.06-47.06V79.06c0-25.9 21.16-47.06 47.06-47.06 25.9 0 47.06 21.16 47.06 47.06V196.9zM283.1 385.88c25.9 0 47.06 21.16 47.06 47.06 0 25.9-21.16 47.06-47.06 47.06-25.9 0-47.06-21.16-47.06-47.06v-47.06h47.06zm0-23.72c-25.9 0-47.06-21.16-47.06-47.06 0-25.9 21.16-47.06 47.06-47.06h117.84c25.9 0 47.06 21.16 47.06 47.06 0 25.9-21.16 47.06-47.06 47.06H283.1z"/></svg>
</a>
</div>
<!-- Color palette toggle -->
<!-- User preference: color palette -->
<!-- Site language selector -->
<!-- Repository information -->
</nav>
<!-- Navigation tabs (sticky) -->
<nav class="md-tabs" aria-label="Tabs" data-md-component="tabs">
<div class="md-grid">
<ul class="md-tabs__list">
<li class="md-tabs__item">
<a href=".." class="md-tabs__link">
Home
</a>
</li>
<li class="md-tabs__item">
<a href="../spark-quickstart/" class="md-tabs__link">
Quickstart
</a>
</li>
<li class="md-tabs__item">
<a href="../docs/latest/" class="md-tabs__link">
Docs
</a>
</li>
<li class="md-tabs__item md-tabs__item--active">
<a href="./" class="md-tabs__link">
Releases
</a>
</li>
<li class="md-tabs__item">
<a href="../roadmap/" class="md-tabs__link">
Roadmap
</a>
</li>
<li class="md-tabs__item">
<a href="../blogs/" class="md-tabs__link">
Blogs
</a>
</li>
<li class="md-tabs__item">
<a href="../talks/" class="md-tabs__link">
Talks
</a>
</li>
<li class="md-tabs__item">
<a href="../vendors/" class="md-tabs__link">
Vendors
</a>
</li>
<li class="md-tabs__item">
<a href="../community/" class="md-tabs__link">
Project
</a>
</li>
<li class="md-tabs__item">
<a href="../catalog/" class="md-tabs__link">
Concepts
</a>
</li>
<li class="md-tabs__item">
<a href="https://www.apache.org/foundation/sponsorship.html" class="md-tabs__link">
ASF
</a>
</li>
</ul>
</div>
</nav>
</header>
<div class="md-container" data-md-component="container">
<main class="md-main" data-md-component="main">
<div class="md-main__inner md-grid">
<div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--primary md-nav--lifted" aria-label="Navigation" data-md-level="0">
<label class="md-nav__title" for="__drawer">
<a href=".." title="Apache Iceberg" class="md-nav__button md-logo" aria-label="Apache Iceberg" data-md-component="logo">
<img src="../assets/images/Iceberg-logo.svg" alt="logo">
</a>
Apache Iceberg
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href=".." class="md-nav__link">
<span class="md-ellipsis">
Home
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_2" >
<label class="md-nav__link" for="__nav_2" id="__nav_2_label" tabindex="">
<span class="md-ellipsis">
Quickstart
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_2">
<span class="md-nav__icon md-icon"></span>
Quickstart
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../spark-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Spark
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../hive-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3" >
<label class="md-nav__link" for="__nav_3" id="__nav_3_label" tabindex="">
<span class="md-ellipsis">
Docs
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3">
<span class="md-nav__icon md-icon"></span>
Docs
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1" >
<label class="md-nav__link" for="__nav_3_1" id="__nav_3_1_label" tabindex="0">
<span class="md-ellipsis">
latest
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_1_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1">
<span class="md-nav__icon md-icon"></span>
latest
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/" class="md-nav__link">
<span class="md-ellipsis">
Introduction
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_2" >
<label class="md-nav__link" for="__nav_3_1_2" id="__nav_3_1_2_label" tabindex="0">
<span class="md-ellipsis">
Tables
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_2">
<span class="md-nav__icon md-icon"></span>
Tables
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/branching/" class="md-nav__link">
<span class="md-ellipsis">
Branching and Tagging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/evolution/" class="md-nav__link">
<span class="md-ellipsis">
Evolution
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/maintenance/" class="md-nav__link">
<span class="md-ellipsis">
Maintenance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/metrics-reporting/" class="md-nav__link">
<span class="md-ellipsis">
Metrics Reporting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/partitioning/" class="md-nav__link">
<span class="md-ellipsis">
Partitioning
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/performance/" class="md-nav__link">
<span class="md-ellipsis">
Performance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/reliability/" class="md-nav__link">
<span class="md-ellipsis">
Reliability
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/schemas/" class="md-nav__link">
<span class="md-ellipsis">
Schemas
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_3" >
<label class="md-nav__link" for="__nav_3_1_3" id="__nav_3_1_3_label" tabindex="0">
<span class="md-ellipsis">
Spark
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_3">
<span class="md-nav__icon md-icon"></span>
Spark
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/spark-getting-started/" class="md-nav__link">
<span class="md-ellipsis">
Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-ddl/" class="md-nav__link">
<span class="md-ellipsis">
DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-procedures/" class="md-nav__link">
<span class="md-ellipsis">
Procedures
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-queries/" class="md-nav__link">
<span class="md-ellipsis">
Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-structured-streaming/" class="md-nav__link">
<span class="md-ellipsis">
Structured Streaming
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/spark-writes/" class="md-nav__link">
<span class="md-ellipsis">
Writes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_4" >
<label class="md-nav__link" for="__nav_3_1_4" id="__nav_3_1_4_label" tabindex="0">
<span class="md-ellipsis">
Flink
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_4">
<span class="md-nav__icon md-icon"></span>
Flink
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/flink/" class="md-nav__link">
<span class="md-ellipsis">
Flink Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-connector/" class="md-nav__link">
<span class="md-ellipsis">
Flink Connector
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-ddl/" class="md-nav__link">
<span class="md-ellipsis">
Flink DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-queries/" class="md-nav__link">
<span class="md-ellipsis">
Flink Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-writes/" class="md-nav__link">
<span class="md-ellipsis">
Flink Writes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-actions/" class="md-nav__link">
<span class="md-ellipsis">
Flink Actions
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/flink-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Flink Configuration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../docs/latest/hive/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://trino.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Trino
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://clickhouse.com/docs/en/engines/table-engines/integrations/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Clickhouse
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://prestodb.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Presto
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.dremio.com/data-formats/apache-iceberg/" class="md-nav__link">
<span class="md-ellipsis">
Dremio
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.starrocks.io/en-us/latest/data_source/catalog/iceberg_catalog" class="md-nav__link">
<span class="md-ellipsis">
Starrocks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/athena/latest/ug/querying-iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon Athena
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/emr/latest/ReleaseGuide/emr-iceberg-use-cluster.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon EMR
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://impala.apache.org/docs/build/html/topics/impala_iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Impala
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://doris.apache.org/docs/dev/lakehouse/multi-catalog/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Doris
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_15" >
<label class="md-nav__link" for="__nav_3_1_15" id="__nav_3_1_15_label" tabindex="0">
<span class="md-ellipsis">
Integrations
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_15">
<span class="md-nav__icon md-icon"></span>
Integrations
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/aws/" class="md-nav__link">
<span class="md-ellipsis">
AWS
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/dell/" class="md-nav__link">
<span class="md-ellipsis">
Dell
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/jdbc/" class="md-nav__link">
<span class="md-ellipsis">
JDBC
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/nessie/" class="md-nav__link">
<span class="md-ellipsis">
Nessie
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_16" >
<label class="md-nav__link" for="__nav_3_1_16" id="__nav_3_1_16_label" tabindex="0">
<span class="md-ellipsis">
API
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_16">
<span class="md-nav__icon md-icon"></span>
API
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/java-api-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Java Quickstart
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/api/" class="md-nav__link">
<span class="md-ellipsis">
Java API
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/custom-catalog/" class="md-nav__link">
<span class="md-ellipsis">
Java Custom Catalog
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_1_17" >
<label class="md-nav__link" for="__nav_3_1_17" id="__nav_3_1_17_label" tabindex="0">
<span class="md-ellipsis">
Migration
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_1_17_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_1_17">
<span class="md-nav__icon md-icon"></span>
Migration
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/latest/table-migration/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/hive-migration/" class="md-nav__link">
<span class="md-ellipsis">
Hive Migration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/latest/delta-lake-migration/" class="md-nav__link">
<span class="md-ellipsis">
Delta Lake Migration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../javadoc/latest" class="md-nav__link">
<span class="md-ellipsis">
Javadoc
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://py.iceberg.apache.org/" class="md-nav__link">
<span class="md-ellipsis">
PyIceberg
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2" >
<label class="md-nav__link" for="__nav_3_2" id="__nav_3_2_label" tabindex="0">
<span class="md-ellipsis">
1.4.3
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2">
<span class="md-nav__icon md-icon"></span>
1.4.3
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/" class="md-nav__link">
<span class="md-ellipsis">
Introduction
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_2" >
<label class="md-nav__link" for="__nav_3_2_2" id="__nav_3_2_2_label" tabindex="0">
<span class="md-ellipsis">
Tables
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_2">
<span class="md-nav__icon md-icon"></span>
Tables
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/branching/" class="md-nav__link">
<span class="md-ellipsis">
Branching and Tagging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/evolution/" class="md-nav__link">
<span class="md-ellipsis">
Evolution
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/maintenance/" class="md-nav__link">
<span class="md-ellipsis">
Maintenance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/metrics-reporting/" class="md-nav__link">
<span class="md-ellipsis">
Metrics Reporting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/partitioning/" class="md-nav__link">
<span class="md-ellipsis">
Partitioning
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/performance/" class="md-nav__link">
<span class="md-ellipsis">
Performance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/reliability/" class="md-nav__link">
<span class="md-ellipsis">
Reliability
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/schemas/" class="md-nav__link">
<span class="md-ellipsis">
Schemas
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_3" >
<label class="md-nav__link" for="__nav_3_2_3" id="__nav_3_2_3_label" tabindex="0">
<span class="md-ellipsis">
Spark
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_3">
<span class="md-nav__icon md-icon"></span>
Spark
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-getting-started/" class="md-nav__link">
<span class="md-ellipsis">
Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-ddl/" class="md-nav__link">
<span class="md-ellipsis">
DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-procedures/" class="md-nav__link">
<span class="md-ellipsis">
Procedures
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-queries/" class="md-nav__link">
<span class="md-ellipsis">
Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-structured-streaming/" class="md-nav__link">
<span class="md-ellipsis">
Structured Streaming
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/spark-writes/" class="md-nav__link">
<span class="md-ellipsis">
Writes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_4" >
<label class="md-nav__link" for="__nav_3_2_4" id="__nav_3_2_4_label" tabindex="0">
<span class="md-ellipsis">
Flink
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_4">
<span class="md-nav__icon md-icon"></span>
Flink
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink/" class="md-nav__link">
<span class="md-ellipsis">
Flink Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-connector/" class="md-nav__link">
<span class="md-ellipsis">
Flink Connector
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-ddl/" class="md-nav__link">
<span class="md-ellipsis">
Flink DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-queries/" class="md-nav__link">
<span class="md-ellipsis">
Flink Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-writes/" class="md-nav__link">
<span class="md-ellipsis">
Flink Writes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-actions/" class="md-nav__link">
<span class="md-ellipsis">
Flink Actions
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/flink-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Flink Configuration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/hive/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://trino.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Trino
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://clickhouse.com/docs/en/engines/table-engines/integrations/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Clickhouse
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://prestodb.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Presto
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.dremio.com/data-formats/apache-iceberg/" class="md-nav__link">
<span class="md-ellipsis">
Dremio
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.starrocks.io/en-us/latest/data_source/catalog/iceberg_catalog" class="md-nav__link">
<span class="md-ellipsis">
Starrocks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/athena/latest/ug/querying-iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon Athena
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/emr/latest/ReleaseGuide/emr-iceberg-use-cluster.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon EMR
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://impala.apache.org/docs/build/html/topics/impala_iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Impala
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://doris.apache.org/docs/dev/lakehouse/multi-catalog/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Doris
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_15" >
<label class="md-nav__link" for="__nav_3_2_15" id="__nav_3_2_15_label" tabindex="0">
<span class="md-ellipsis">
Integrations
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_15">
<span class="md-nav__icon md-icon"></span>
Integrations
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/aws/" class="md-nav__link">
<span class="md-ellipsis">
AWS
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/dell/" class="md-nav__link">
<span class="md-ellipsis">
Dell
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/jdbc/" class="md-nav__link">
<span class="md-ellipsis">
JDBC
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/nessie/" class="md-nav__link">
<span class="md-ellipsis">
Nessie
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_16" >
<label class="md-nav__link" for="__nav_3_2_16" id="__nav_3_2_16_label" tabindex="0">
<span class="md-ellipsis">
API
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_16">
<span class="md-nav__icon md-icon"></span>
API
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/java-api-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Java Quickstart
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/api/" class="md-nav__link">
<span class="md-ellipsis">
Java API
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/custom-catalog/" class="md-nav__link">
<span class="md-ellipsis">
Java Custom Catalog
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_2_17" >
<label class="md-nav__link" for="__nav_3_2_17" id="__nav_3_2_17_label" tabindex="0">
<span class="md-ellipsis">
Migration
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_17_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_2_17">
<span class="md-nav__icon md-icon"></span>
Migration
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.3/table-migration/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/hive-migration/" class="md-nav__link">
<span class="md-ellipsis">
Hive Migration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.3/delta-lake-migration/" class="md-nav__link">
<span class="md-ellipsis">
Delta Lake Migration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../javadoc/1.4.3" class="md-nav__link">
<span class="md-ellipsis">
Javadoc
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://py.iceberg.apache.org/" class="md-nav__link">
<span class="md-ellipsis">
PyIceberg
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3" >
<label class="md-nav__link" for="__nav_3_3" id="__nav_3_3_label" tabindex="0">
<span class="md-ellipsis">
1.4.2
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3">
<span class="md-nav__icon md-icon"></span>
1.4.2
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/" class="md-nav__link">
<span class="md-ellipsis">
Introduction
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_2" >
<label class="md-nav__link" for="__nav_3_3_2" id="__nav_3_3_2_label" tabindex="0">
<span class="md-ellipsis">
Tables
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_2">
<span class="md-nav__icon md-icon"></span>
Tables
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/branching/" class="md-nav__link">
<span class="md-ellipsis">
Branching and Tagging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/evolution/" class="md-nav__link">
<span class="md-ellipsis">
Evolution
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/maintenance/" class="md-nav__link">
<span class="md-ellipsis">
Maintenance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/metrics-reporting/" class="md-nav__link">
<span class="md-ellipsis">
Metrics Reporting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/partitioning/" class="md-nav__link">
<span class="md-ellipsis">
Partitioning
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/performance/" class="md-nav__link">
<span class="md-ellipsis">
Performance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/reliability/" class="md-nav__link">
<span class="md-ellipsis">
Reliability
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/schemas/" class="md-nav__link">
<span class="md-ellipsis">
Schemas
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_3" >
<label class="md-nav__link" for="__nav_3_3_3" id="__nav_3_3_3_label" tabindex="0">
<span class="md-ellipsis">
Spark
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_3">
<span class="md-nav__icon md-icon"></span>
Spark
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-getting-started/" class="md-nav__link">
<span class="md-ellipsis">
Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-ddl/" class="md-nav__link">
<span class="md-ellipsis">
DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-procedures/" class="md-nav__link">
<span class="md-ellipsis">
Procedures
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-queries/" class="md-nav__link">
<span class="md-ellipsis">
Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-structured-streaming/" class="md-nav__link">
<span class="md-ellipsis">
Structured Streaming
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/spark-writes/" class="md-nav__link">
<span class="md-ellipsis">
Writes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_4" >
<label class="md-nav__link" for="__nav_3_3_4" id="__nav_3_3_4_label" tabindex="0">
<span class="md-ellipsis">
Flink
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_4">
<span class="md-nav__icon md-icon"></span>
Flink
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink/" class="md-nav__link">
<span class="md-ellipsis">
Flink Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-connector/" class="md-nav__link">
<span class="md-ellipsis">
Flink Connector
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-ddl/" class="md-nav__link">
<span class="md-ellipsis">
Flink DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-queries/" class="md-nav__link">
<span class="md-ellipsis">
Flink Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-writes/" class="md-nav__link">
<span class="md-ellipsis">
Flink Writes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-actions/" class="md-nav__link">
<span class="md-ellipsis">
Flink Actions
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/flink-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Flink Configuration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/hive/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://trino.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Trino
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://clickhouse.com/docs/en/engines/table-engines/integrations/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Clickhouse
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://prestodb.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Presto
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.dremio.com/data-formats/apache-iceberg/" class="md-nav__link">
<span class="md-ellipsis">
Dremio
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.starrocks.io/en-us/latest/data_source/catalog/iceberg_catalog" class="md-nav__link">
<span class="md-ellipsis">
Starrocks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/athena/latest/ug/querying-iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon Athena
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/emr/latest/ReleaseGuide/emr-iceberg-use-cluster.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon EMR
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://impala.apache.org/docs/build/html/topics/impala_iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Impala
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://doris.apache.org/docs/dev/lakehouse/multi-catalog/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Doris
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_15" >
<label class="md-nav__link" for="__nav_3_3_15" id="__nav_3_3_15_label" tabindex="0">
<span class="md-ellipsis">
Integrations
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_15">
<span class="md-nav__icon md-icon"></span>
Integrations
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/aws/" class="md-nav__link">
<span class="md-ellipsis">
AWS
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/dell/" class="md-nav__link">
<span class="md-ellipsis">
Dell
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/jdbc/" class="md-nav__link">
<span class="md-ellipsis">
JDBC
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/nessie/" class="md-nav__link">
<span class="md-ellipsis">
Nessie
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_16" >
<label class="md-nav__link" for="__nav_3_3_16" id="__nav_3_3_16_label" tabindex="0">
<span class="md-ellipsis">
API
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_16">
<span class="md-nav__icon md-icon"></span>
API
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/java-api-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Java Quickstart
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/api/" class="md-nav__link">
<span class="md-ellipsis">
Java API
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/custom-catalog/" class="md-nav__link">
<span class="md-ellipsis">
Java Custom Catalog
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_3_17" >
<label class="md-nav__link" for="__nav_3_3_17" id="__nav_3_3_17_label" tabindex="0">
<span class="md-ellipsis">
Migration
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_3_17_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_3_17">
<span class="md-nav__icon md-icon"></span>
Migration
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.2/table-migration/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/hive-migration/" class="md-nav__link">
<span class="md-ellipsis">
Hive Migration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.2/delta-lake-migration/" class="md-nav__link">
<span class="md-ellipsis">
Delta Lake Migration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../javadoc/1.4.2" class="md-nav__link">
<span class="md-ellipsis">
Javadoc
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://py.iceberg.apache.org/" class="md-nav__link">
<span class="md-ellipsis">
PyIceberg
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4" >
<label class="md-nav__link" for="__nav_3_4" id="__nav_3_4_label" tabindex="0">
<span class="md-ellipsis">
1.4.1
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4">
<span class="md-nav__icon md-icon"></span>
1.4.1
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/" class="md-nav__link">
<span class="md-ellipsis">
Introduction
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_2" >
<label class="md-nav__link" for="__nav_3_4_2" id="__nav_3_4_2_label" tabindex="0">
<span class="md-ellipsis">
Tables
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_2">
<span class="md-nav__icon md-icon"></span>
Tables
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/branching/" class="md-nav__link">
<span class="md-ellipsis">
Branching and Tagging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/evolution/" class="md-nav__link">
<span class="md-ellipsis">
Evolution
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/maintenance/" class="md-nav__link">
<span class="md-ellipsis">
Maintenance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/metrics-reporting/" class="md-nav__link">
<span class="md-ellipsis">
Metrics Reporting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/partitioning/" class="md-nav__link">
<span class="md-ellipsis">
Partitioning
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/performance/" class="md-nav__link">
<span class="md-ellipsis">
Performance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/reliability/" class="md-nav__link">
<span class="md-ellipsis">
Reliability
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/schemas/" class="md-nav__link">
<span class="md-ellipsis">
Schemas
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_3" >
<label class="md-nav__link" for="__nav_3_4_3" id="__nav_3_4_3_label" tabindex="0">
<span class="md-ellipsis">
Spark
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_3">
<span class="md-nav__icon md-icon"></span>
Spark
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-getting-started/" class="md-nav__link">
<span class="md-ellipsis">
Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-ddl/" class="md-nav__link">
<span class="md-ellipsis">
DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-procedures/" class="md-nav__link">
<span class="md-ellipsis">
Procedures
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-queries/" class="md-nav__link">
<span class="md-ellipsis">
Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-structured-streaming/" class="md-nav__link">
<span class="md-ellipsis">
Structured Streaming
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/spark-writes/" class="md-nav__link">
<span class="md-ellipsis">
Writes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_4" >
<label class="md-nav__link" for="__nav_3_4_4" id="__nav_3_4_4_label" tabindex="0">
<span class="md-ellipsis">
Flink
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_4">
<span class="md-nav__icon md-icon"></span>
Flink
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink/" class="md-nav__link">
<span class="md-ellipsis">
Flink Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-connector/" class="md-nav__link">
<span class="md-ellipsis">
Flink Connector
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-ddl/" class="md-nav__link">
<span class="md-ellipsis">
Flink DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-queries/" class="md-nav__link">
<span class="md-ellipsis">
Flink Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-writes/" class="md-nav__link">
<span class="md-ellipsis">
Flink Writes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-actions/" class="md-nav__link">
<span class="md-ellipsis">
Flink Actions
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/flink-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Flink Configuration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/hive/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://trino.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Trino
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://clickhouse.com/docs/en/engines/table-engines/integrations/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Clickhouse
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://prestodb.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Presto
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.dremio.com/data-formats/apache-iceberg/" class="md-nav__link">
<span class="md-ellipsis">
Dremio
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.starrocks.io/en-us/latest/data_source/catalog/iceberg_catalog" class="md-nav__link">
<span class="md-ellipsis">
Starrocks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/athena/latest/ug/querying-iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon Athena
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/emr/latest/ReleaseGuide/emr-iceberg-use-cluster.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon EMR
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://impala.apache.org/docs/build/html/topics/impala_iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Impala
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://doris.apache.org/docs/dev/lakehouse/multi-catalog/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Doris
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_15" >
<label class="md-nav__link" for="__nav_3_4_15" id="__nav_3_4_15_label" tabindex="0">
<span class="md-ellipsis">
Integrations
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_15">
<span class="md-nav__icon md-icon"></span>
Integrations
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/aws/" class="md-nav__link">
<span class="md-ellipsis">
AWS
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/dell/" class="md-nav__link">
<span class="md-ellipsis">
Dell
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/jdbc/" class="md-nav__link">
<span class="md-ellipsis">
JDBC
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/nessie/" class="md-nav__link">
<span class="md-ellipsis">
Nessie
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_16" >
<label class="md-nav__link" for="__nav_3_4_16" id="__nav_3_4_16_label" tabindex="0">
<span class="md-ellipsis">
API
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_16">
<span class="md-nav__icon md-icon"></span>
API
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/java-api-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Java Quickstart
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/api/" class="md-nav__link">
<span class="md-ellipsis">
Java API
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/custom-catalog/" class="md-nav__link">
<span class="md-ellipsis">
Java Custom Catalog
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_4_17" >
<label class="md-nav__link" for="__nav_3_4_17" id="__nav_3_4_17_label" tabindex="0">
<span class="md-ellipsis">
Migration
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_4_17_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_4_17">
<span class="md-nav__icon md-icon"></span>
Migration
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.1/table-migration/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/hive-migration/" class="md-nav__link">
<span class="md-ellipsis">
Hive Migration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.1/delta-lake-migration/" class="md-nav__link">
<span class="md-ellipsis">
Delta Lake Migration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../javadoc/1.4.1/" class="md-nav__link">
<span class="md-ellipsis">
Javadoc
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://py.iceberg.apache.org/" class="md-nav__link">
<span class="md-ellipsis">
PyIceberg
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5" >
<label class="md-nav__link" for="__nav_3_5" id="__nav_3_5_label" tabindex="0">
<span class="md-ellipsis">
1.4.0
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_5_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5">
<span class="md-nav__icon md-icon"></span>
1.4.0
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/" class="md-nav__link">
<span class="md-ellipsis">
Introduction
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_2" >
<label class="md-nav__link" for="__nav_3_5_2" id="__nav_3_5_2_label" tabindex="0">
<span class="md-ellipsis">
Tables
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_2">
<span class="md-nav__icon md-icon"></span>
Tables
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/branching/" class="md-nav__link">
<span class="md-ellipsis">
Branching and Tagging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/evolution/" class="md-nav__link">
<span class="md-ellipsis">
Evolution
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/maintenance/" class="md-nav__link">
<span class="md-ellipsis">
Maintenance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/metrics-reporting/" class="md-nav__link">
<span class="md-ellipsis">
Metrics Reporting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/partitioning/" class="md-nav__link">
<span class="md-ellipsis">
Partitioning
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/performance/" class="md-nav__link">
<span class="md-ellipsis">
Performance
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/reliability/" class="md-nav__link">
<span class="md-ellipsis">
Reliability
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/schemas/" class="md-nav__link">
<span class="md-ellipsis">
Schemas
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_3" >
<label class="md-nav__link" for="__nav_3_5_3" id="__nav_3_5_3_label" tabindex="0">
<span class="md-ellipsis">
Spark
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_3">
<span class="md-nav__icon md-icon"></span>
Spark
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-getting-started/" class="md-nav__link">
<span class="md-ellipsis">
Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Configuration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-ddl/" class="md-nav__link">
<span class="md-ellipsis">
DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-procedures/" class="md-nav__link">
<span class="md-ellipsis">
Procedures
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-queries/" class="md-nav__link">
<span class="md-ellipsis">
Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-structured-streaming/" class="md-nav__link">
<span class="md-ellipsis">
Structured Streaming
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/spark-writes/" class="md-nav__link">
<span class="md-ellipsis">
Writes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_4" >
<label class="md-nav__link" for="__nav_3_5_4" id="__nav_3_5_4_label" tabindex="0">
<span class="md-ellipsis">
Flink
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_4_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_4">
<span class="md-nav__icon md-icon"></span>
Flink
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink/" class="md-nav__link">
<span class="md-ellipsis">
Flink Getting Started
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-connector/" class="md-nav__link">
<span class="md-ellipsis">
Flink Connector
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-ddl/" class="md-nav__link">
<span class="md-ellipsis">
Flink DDL
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-queries/" class="md-nav__link">
<span class="md-ellipsis">
Flink Queries
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-writes/" class="md-nav__link">
<span class="md-ellipsis">
Flink Writes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-actions/" class="md-nav__link">
<span class="md-ellipsis">
Flink Actions
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/flink-configuration/" class="md-nav__link">
<span class="md-ellipsis">
Flink Configuration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/hive/" class="md-nav__link">
<span class="md-ellipsis">
Hive
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://trino.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Trino
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://clickhouse.com/docs/en/engines/table-engines/integrations/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Clickhouse
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://prestodb.io/docs/current/connector/iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Presto
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.dremio.com/data-formats/apache-iceberg/" class="md-nav__link">
<span class="md-ellipsis">
Dremio
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.starrocks.io/en-us/latest/data_source/catalog/iceberg_catalog" class="md-nav__link">
<span class="md-ellipsis">
Starrocks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/athena/latest/ug/querying-iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon Athena
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://docs.aws.amazon.com/emr/latest/ReleaseGuide/emr-iceberg-use-cluster.html" class="md-nav__link">
<span class="md-ellipsis">
Amazon EMR
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://impala.apache.org/docs/build/html/topics/impala_iceberg.html" class="md-nav__link">
<span class="md-ellipsis">
Impala
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://doris.apache.org/docs/dev/lakehouse/multi-catalog/iceberg" class="md-nav__link">
<span class="md-ellipsis">
Doris
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_15" >
<label class="md-nav__link" for="__nav_3_5_15" id="__nav_3_5_15_label" tabindex="0">
<span class="md-ellipsis">
Integrations
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_15_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_15">
<span class="md-nav__icon md-icon"></span>
Integrations
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/aws/" class="md-nav__link">
<span class="md-ellipsis">
AWS
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/dell/" class="md-nav__link">
<span class="md-ellipsis">
Dell
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/jdbc/" class="md-nav__link">
<span class="md-ellipsis">
JDBC
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/nessie/" class="md-nav__link">
<span class="md-ellipsis">
Nessie
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_16" >
<label class="md-nav__link" for="__nav_3_5_16" id="__nav_3_5_16_label" tabindex="0">
<span class="md-ellipsis">
API
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_16_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_16">
<span class="md-nav__icon md-icon"></span>
API
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/java-api-quickstart/" class="md-nav__link">
<span class="md-ellipsis">
Java Quickstart
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/api/" class="md-nav__link">
<span class="md-ellipsis">
Java API
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/custom-catalog/" class="md-nav__link">
<span class="md-ellipsis">
Java Custom Catalog
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3_5_17" >
<label class="md-nav__link" for="__nav_3_5_17" id="__nav_3_5_17_label" tabindex="0">
<span class="md-ellipsis">
Migration
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_5_17_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3_5_17">
<span class="md-nav__icon md-icon"></span>
Migration
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../docs/1.4.0/table-migration/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/hive-migration/" class="md-nav__link">
<span class="md-ellipsis">
Hive Migration
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../docs/1.4.0/delta-lake-migration/" class="md-nav__link">
<span class="md-ellipsis">
Delta Lake Migration
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../javadoc/1.4.0/" class="md-nav__link">
<span class="md-ellipsis">
Javadoc
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://py.iceberg.apache.org/" class="md-nav__link">
<span class="md-ellipsis">
PyIceberg
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--active">
<input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
<label class="md-nav__link md-nav__link--active" for="__toc">
<span class="md-ellipsis">
Releases
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<a href="./" class="md-nav__link md-nav__link--active">
<span class="md-ellipsis">
Releases
</span>
</a>
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#downloads" class="md-nav__link">
<span class="md-ellipsis">
Downloads
</span>
</a>
<nav class="md-nav" aria-label="Downloads">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#gradle" class="md-nav__link">
<span class="md-ellipsis">
Gradle
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#maven" class="md-nav__link">
<span class="md-ellipsis">
Maven
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#143-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.3 Release
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#past-releases" class="md-nav__link">
<span class="md-ellipsis">
Past releases
</span>
</a>
<nav class="md-nav" aria-label="Past releases">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#142-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.2 Release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#141-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.1 Release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#140-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#131-release" class="md-nav__link">
<span class="md-ellipsis">
1.3.1 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#130-release" class="md-nav__link">
<span class="md-ellipsis">
1.3.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#121-release" class="md-nav__link">
<span class="md-ellipsis">
1.2.1 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#120-release" class="md-nav__link">
<span class="md-ellipsis">
1.2.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#110-release" class="md-nav__link">
<span class="md-ellipsis">
1.1.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#100-release" class="md-nav__link">
<span class="md-ellipsis">
1.0.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0141-release" class="md-nav__link">
<span class="md-ellipsis">
0.14.1 release
</span>
</a>
<nav class="md-nav" aria-label="0.14.1 release">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#notable-bug-fixes" class="md-nav__link">
<span class="md-ellipsis">
Notable bug fixes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#0140-release" class="md-nav__link">
<span class="md-ellipsis">
0.14.0 release
</span>
</a>
<nav class="md-nav" aria-label="0.14.0 release">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#highlights" class="md-nav__link">
<span class="md-ellipsis">
Highlights
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#high-level-features" class="md-nav__link">
<span class="md-ellipsis">
High-level features
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#performance-improvements" class="md-nav__link">
<span class="md-ellipsis">
Performance improvements
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#notable-bug-fixes_1" class="md-nav__link">
<span class="md-ellipsis">
Notable bug fixes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#dependency-changes" class="md-nav__link">
<span class="md-ellipsis">
Dependency changes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#0132" class="md-nav__link">
<span class="md-ellipsis">
0.13.2
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0131" class="md-nav__link">
<span class="md-ellipsis">
0.13.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0130" class="md-nav__link">
<span class="md-ellipsis">
0.13.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0121" class="md-nav__link">
<span class="md-ellipsis">
0.12.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0120" class="md-nav__link">
<span class="md-ellipsis">
0.12.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0111" class="md-nav__link">
<span class="md-ellipsis">
0.11.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0110" class="md-nav__link">
<span class="md-ellipsis">
0.11.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0100" class="md-nav__link">
<span class="md-ellipsis">
0.10.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#091" class="md-nav__link">
<span class="md-ellipsis">
0.9.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#090" class="md-nav__link">
<span class="md-ellipsis">
0.9.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#080" class="md-nav__link">
<span class="md-ellipsis">
0.8.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#070" class="md-nav__link">
<span class="md-ellipsis">
0.7.0
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../roadmap/" class="md-nav__link">
<span class="md-ellipsis">
Roadmap
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../blogs/" class="md-nav__link">
<span class="md-ellipsis">
Blogs
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../talks/" class="md-nav__link">
<span class="md-ellipsis">
Talks
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../vendors/" class="md-nav__link">
<span class="md-ellipsis">
Vendors
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_9" >
<label class="md-nav__link" for="__nav_9" id="__nav_9_label" tabindex="">
<span class="md-ellipsis">
Project
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_9_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_9">
<span class="md-nav__icon md-icon"></span>
Project
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../community/" class="md-nav__link">
<span class="md-ellipsis">
Join
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../spec/" class="md-nav__link">
<span class="md-ellipsis">
Spec
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../view-spec/" class="md-nav__link">
<span class="md-ellipsis">
View spec
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../puffin-spec/" class="md-nav__link">
<span class="md-ellipsis">
Puffin spec
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../multi-engine-support/" class="md-nav__link">
<span class="md-ellipsis">
Multi-engine support
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../how-to-release/" class="md-nav__link">
<span class="md-ellipsis">
How to release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../terms/" class="md-nav__link">
<span class="md-ellipsis">
Terms
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_10" >
<label class="md-nav__link" for="__nav_10" id="__nav_10_label" tabindex="">
<span class="md-ellipsis">
Concepts
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_10_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_10">
<span class="md-nav__icon md-icon"></span>
Concepts
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../catalog/" class="md-nav__link">
<span class="md-ellipsis">
Catalogs
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--section md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_11" >
<label class="md-nav__link" for="__nav_11" id="__nav_11_label" tabindex="">
<span class="md-ellipsis">
ASF
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_11_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_11">
<span class="md-nav__icon md-icon"></span>
ASF
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="https://www.apache.org/foundation/sponsorship.html" class="md-nav__link">
<span class="md-ellipsis">
Sponsorship
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://www.apache.org/events/current-event.html" class="md-nav__link">
<span class="md-ellipsis">
Events
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://www.apache.org/licenses/" class="md-nav__link">
<span class="md-ellipsis">
License
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://www.apache.org/security/" class="md-nav__link">
<span class="md-ellipsis">
Security
</span>
</a>
</li>
<li class="md-nav__item">
<a href="https://www.apache.org/foundation/thanks.html" class="md-nav__link">
<span class="md-ellipsis">
Sponsors
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#downloads" class="md-nav__link">
<span class="md-ellipsis">
Downloads
</span>
</a>
<nav class="md-nav" aria-label="Downloads">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#gradle" class="md-nav__link">
<span class="md-ellipsis">
Gradle
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#maven" class="md-nav__link">
<span class="md-ellipsis">
Maven
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#143-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.3 Release
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#past-releases" class="md-nav__link">
<span class="md-ellipsis">
Past releases
</span>
</a>
<nav class="md-nav" aria-label="Past releases">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#142-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.2 Release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#141-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.1 Release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#140-release" class="md-nav__link">
<span class="md-ellipsis">
1.4.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#131-release" class="md-nav__link">
<span class="md-ellipsis">
1.3.1 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#130-release" class="md-nav__link">
<span class="md-ellipsis">
1.3.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#121-release" class="md-nav__link">
<span class="md-ellipsis">
1.2.1 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#120-release" class="md-nav__link">
<span class="md-ellipsis">
1.2.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#110-release" class="md-nav__link">
<span class="md-ellipsis">
1.1.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#100-release" class="md-nav__link">
<span class="md-ellipsis">
1.0.0 release
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0141-release" class="md-nav__link">
<span class="md-ellipsis">
0.14.1 release
</span>
</a>
<nav class="md-nav" aria-label="0.14.1 release">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#notable-bug-fixes" class="md-nav__link">
<span class="md-ellipsis">
Notable bug fixes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#0140-release" class="md-nav__link">
<span class="md-ellipsis">
0.14.0 release
</span>
</a>
<nav class="md-nav" aria-label="0.14.0 release">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#highlights" class="md-nav__link">
<span class="md-ellipsis">
Highlights
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#high-level-features" class="md-nav__link">
<span class="md-ellipsis">
High-level features
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#performance-improvements" class="md-nav__link">
<span class="md-ellipsis">
Performance improvements
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#notable-bug-fixes_1" class="md-nav__link">
<span class="md-ellipsis">
Notable bug fixes
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#dependency-changes" class="md-nav__link">
<span class="md-ellipsis">
Dependency changes
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#0132" class="md-nav__link">
<span class="md-ellipsis">
0.13.2
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0131" class="md-nav__link">
<span class="md-ellipsis">
0.13.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0130" class="md-nav__link">
<span class="md-ellipsis">
0.13.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0121" class="md-nav__link">
<span class="md-ellipsis">
0.12.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0120" class="md-nav__link">
<span class="md-ellipsis">
0.12.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0111" class="md-nav__link">
<span class="md-ellipsis">
0.11.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0110" class="md-nav__link">
<span class="md-ellipsis">
0.11.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#0100" class="md-nav__link">
<span class="md-ellipsis">
0.10.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#091" class="md-nav__link">
<span class="md-ellipsis">
0.9.1
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#090" class="md-nav__link">
<span class="md-ellipsis">
0.9.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#080" class="md-nav__link">
<span class="md-ellipsis">
0.8.0
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#070" class="md-nav__link">
<span class="md-ellipsis">
0.7.0
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-content" data-md-component="content">
<article class="md-content__inner md-typeset">
<h1>Releases</h1>
<!--
- Licensed to the Apache Software Foundation (ASF) under one or more
- contributor license agreements. See the NOTICE file distributed with
- this work for additional information regarding copyright ownership.
- The ASF licenses this file to You under the Apache License, Version 2.0
- (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
-->
<h2 id="downloads">Downloads<a class="headerlink" href="#downloads" title="Permanent link">🔗</a></h2>
<p>The latest version of Iceberg is <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-1.4.3">1.4.3</a>.</p>
<ul>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-1.4.3/apache-iceberg-1.4.3.tar.gz">1.4.3 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-1.4.3/apache-iceberg-1.4.3.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-1.4.3/apache-iceberg-1.4.3.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.5_2.12/1.4.3/iceberg-spark-runtime-3.5_2.12-1.4.3.jar">1.4.3 Spark 3.5_2.12 runtime Jar</a> -- <a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.5_2.13/1.4.3/iceberg-spark-runtime-3.5_2.13-1.4.3.jar">3.5_2.13</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.4_2.12/1.4.3/iceberg-spark-runtime-3.4_2.12-1.4.3.jar">1.4.3 Spark 3.4_2.12 runtime Jar</a> -- <a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.4_2.13/1.4.3/iceberg-spark-runtime-3.4_2.13-1.4.3.jar">3.4_2.13</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.3_2.12/1.4.3/iceberg-spark-runtime-3.3_2.12-1.4.3.jar">1.4.3 Spark 3.3_2.12 runtime Jar</a> -- <a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.3_2.13/1.4.3/iceberg-spark-runtime-3.3_2.13-1.4.3.jar">3.3_2.13</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.2_2.12/1.4.3/iceberg-spark-runtime-3.2_2.12-1.4.3.jar">1.4.3 Spark 3.2_2.12 runtime Jar</a> -- <a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.2_2.13/1.4.3/iceberg-spark-runtime-3.2_2.13-1.4.3.jar">3.2_2.13</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.17/1.4.3/iceberg-flink-runtime-1.17-1.4.3.jar">1.4.3 Flink 1.17 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.16/1.4.3/iceberg-flink-runtime-1.16-1.4.3.jar">1.4.3 Flink 1.16 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.15/1.4.3/iceberg-flink-runtime-1.15-1.4.3.jar">1.4.3 Flink 1.15 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/1.4.3/iceberg-hive-runtime-1.4.3.jar">1.4.3 Hive runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-aws-bundle/1.4.3/iceberg-aws-bundle-1.4.3.jar">1.4.3 aws-bundle Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-gcp-bundle/1.4.3/iceberg-gcp-bundle-1.4.3.jar">1.4.3 gcp-bundle Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-azure-bundle/1.4.3/iceberg-azure-bundle-1.4.3.jar">1.4.3 azure-bundle Jar</a></li>
</ul>
<p>To use Iceberg in Spark or Flink, download the runtime JAR for your engine version and add it to the jars folder of your installation.</p>
<p>To use Iceberg in Hive 2 or Hive 3, download the Hive runtime JAR and add it to Hive using <code>ADD JAR</code>.</p>
<h3 id="gradle">Gradle<a class="headerlink" href="#gradle" title="Permanent link">🔗</a></h3>
<p>To add a dependency on Iceberg in Gradle, add the following to <code>build.gradle</code>:</p>
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a>dependencies {
<a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a> compile &#39;org.apache.iceberg:iceberg-core:1.4.3&#39;
<a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a>}
</code></pre></div>
<p>You may also want to include <code>iceberg-parquet</code> for Parquet file support.</p>
<h3 id="maven">Maven<a class="headerlink" href="#maven" title="Permanent link">🔗</a></h3>
<p>To add a dependency on Iceberg in Maven, add the following to your <code>pom.xml</code>:</p>
<div class="highlight"><pre><span></span><code><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a>&lt;dependencies&gt;
<a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a> ...
<a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a> &lt;dependency&gt;
<a id="__codelineno-1-4" name="__codelineno-1-4" href="#__codelineno-1-4"></a> &lt;groupId&gt;org.apache.iceberg&lt;/groupId&gt;
<a id="__codelineno-1-5" name="__codelineno-1-5" href="#__codelineno-1-5"></a> &lt;artifactId&gt;iceberg-core&lt;/artifactId&gt;
<a id="__codelineno-1-6" name="__codelineno-1-6" href="#__codelineno-1-6"></a> &lt;version&gt;1.4.3&lt;/version&gt;
<a id="__codelineno-1-7" name="__codelineno-1-7" href="#__codelineno-1-7"></a> &lt;/dependency&gt;
<a id="__codelineno-1-8" name="__codelineno-1-8" href="#__codelineno-1-8"></a> ...
<a id="__codelineno-1-9" name="__codelineno-1-9" href="#__codelineno-1-9"></a>&lt;/dependencies&gt;
</code></pre></div>
<h3 id="143-release">1.4.3 Release<a class="headerlink" href="#143-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.4.3 was released on December 27, 2023. The main issue it solves is missing files from a transaction retry with conflicting manifests. It is recommended to upgrade if you use transactions.</p>
<ul>
<li>Core: Scan only live entries in partitions table (#8969) by @Fokko in <a href="https://github.com/apache/iceberg/pull/9197">#9197</a></li>
<li>Core: Fix missing files from transaction retries with conflicting manifest merges by <a href="https://github.com/nastra">@nastra</a> in <a href="https://github.com/apache/iceberg/pull/9337">#9337</a></li>
<li>JDBC Catalog: Fix namespaceExists check with special characters by <a href="https://github.com/ismailsimsek">@ismailsimsek</a> in <a href="https://github.com/apache/iceberg/pull/9291">#9291</a></li>
<li>Core: Expired Snapshot files in a transaction should be deleted by <a href="https://github.com/bartash">@bartash</a> in <a href="https://github.com/apache/iceberg/pull/9223">#9223</a></li>
<li>Core: Fix missing delete files from transaction by <a href="https://github.com/nastra">@nastra</a> in <a href="https://github.com/apache/iceberg/pull/9356">#9356</a></li>
</ul>
<h2 id="past-releases">Past releases<a class="headerlink" href="#past-releases" title="Permanent link">🔗</a></h2>
<h3 id="142-release">1.4.2 Release<a class="headerlink" href="#142-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.4.2 was released on November 2, 2023.
The 1.4.2 patch release addresses fixing a remaining case where split offsets
should be ignored when they are deemed invalid.</p>
<ul>
<li>Core</li>
<li>Core: Ignore split offsets array when split offset is past file length (<a href="https://github.com/apache/iceberg/pull/8925">#8925</a>)</li>
</ul>
<h3 id="141-release">1.4.1 Release<a class="headerlink" href="#141-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.4.1 was released on October 23, 2023.
The 1.4.1 release addresses various issues identified in the 1.4.0 release.</p>
<ul>
<li>Core</li>
<li>Core: Do not use a lazy split offset list in manifests (<a href="https://github.com/apache/iceberg/pull/8834">#8834</a>)</li>
<li>Core: Ignore split offsets when the last split offset is past the file length (<a href="https://github.com/apache/iceberg/pull/8860">#8860</a>)</li>
<li>AWS</li>
<li>Avoid static global credentials provider which doesn't play well with lifecycle management (<a href="https://github.com/apache/iceberg/pull/8677">#8677</a>)</li>
<li>Flink</li>
<li>Reverting the default custom partitioner for bucket column (<a href="https://github.com/apache/iceberg/pull/8848">#8848</a>)</li>
</ul>
<h3 id="140-release">1.4.0 release<a class="headerlink" href="#140-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.4.0 was released on October 4, 2023.
The 1.4.0 release adds a variety of new features and bug fixes.</p>
<ul>
<li>API</li>
<li>Implement bound expression sanitization (<a href="https://github.com/apache/iceberg/pull/8149">#8149</a>)</li>
<li>Remove overflow checks in <code>DefaultCounter</code> causing performance issues (<a href="https://github.com/apache/iceberg/pull/8297">#8297</a>)</li>
<li>Support incremental scanning with branch (<a href="https://github.com/apache/iceberg/pull/5984">#5984</a>)</li>
<li>Add a validation API to <code>DeleteFiles</code> which validates files exist (<a href="https://github.com/apache/iceberg/pull/8525">#8525</a>)</li>
<li>Core</li>
<li>Use V2 format by default in new tables (<a href="https://github.com/apache/iceberg/pull/8381">#8381</a>)</li>
<li>Use <code>zstd</code> compression for Parquet by default in new tables (<a href="https://github.com/apache/iceberg/pull/8593">#8593</a>)</li>
<li>Add strict metadata cleanup mode and enable it by default (<a href="https://github.com/apache/iceberg/pull/8397">#8397</a>) (<a href="https://github.com/apache/iceberg/pull/8599">#8599</a>)</li>
<li>Avoid generating huge manifests during commits (<a href="https://github.com/apache/iceberg/pull/6335">#6335</a>)</li>
<li>Add a writer for unordered position deletes (<a href="https://github.com/apache/iceberg/pull/7692">#7692</a>)</li>
<li>Optimize <code>DeleteFileIndex</code> (<a href="https://github.com/apache/iceberg/pull/8157">#8157</a>)</li>
<li>Optimize lookup in <code>DeleteFileIndex</code> without useful bounds (<a href="https://github.com/apache/iceberg/pull/8278">#8278</a>)</li>
<li>Optimize split offsets handling (<a href="https://github.com/apache/iceberg/pull/8336">#8336</a>)</li>
<li>Optimize computing user-facing state in data tasks (<a href="https://github.com/apache/iceberg/pull/8346">#8346</a>)</li>
<li>Don't persist useless file and position bounds for deletes (<a href="https://github.com/apache/iceberg/pull/8360">#8360</a>)</li>
<li>Don't persist counts for paths and positions in position delete files (<a href="https://github.com/apache/iceberg/pull/8590">#8590</a>)</li>
<li>Support setting system-level properties via environmental variables (<a href="https://github.com/apache/iceberg/pull/5659">#5659</a>)</li>
<li>Add JSON parser for <code>ContentFile</code> and <code>FileScanTask</code> (<a href="https://github.com/apache/iceberg/pull/6934">#6934</a>)</li>
<li>Add REST spec and request for commits to multiple tables (<a href="https://github.com/apache/iceberg/pull/7741">#7741</a>)</li>
<li>Add REST API for committing changes against multiple tables (<a href="https://github.com/apache/iceberg/pull/7569">#7569</a>)</li>
<li>Default to exponential retry strategy in REST client (<a href="https://github.com/apache/iceberg/pull/8366">#8366</a>)</li>
<li>Support registering tables with REST session catalog (<a href="https://github.com/apache/iceberg/pull/6512">#6512</a>)</li>
<li>Add last updated timestamp and snapshot ID to partitions metadata table (<a href="https://github.com/apache/iceberg/pull/7581">#7581</a>)</li>
<li>Add total data size to partitions metadata table (<a href="https://github.com/apache/iceberg/pull/7920">#7920</a>)</li>
<li>Extend <code>ResolvingFileIO</code> to support bulk operations (<a href="https://github.com/apache/iceberg/pull/7976">#7976</a>)</li>
<li>Key metadata in Avro format (<a href="https://github.com/apache/iceberg/pull/6450">#6450</a>)</li>
<li>Add AES GCM encryption stream (<a href="https://github.com/apache/iceberg/pull/3231">#3231</a>)</li>
<li>Fix a connection leak in streaming delete filters (<a href="https://github.com/apache/iceberg/pull/8132">#8132</a>)</li>
<li>Fix lazy snapshot loading history (<a href="https://github.com/apache/iceberg/pull/8470">#8470</a>)</li>
<li>Fix unicode handling in HTTPClient (<a href="https://github.com/apache/iceberg/pull/8046">#8046</a>)</li>
<li>Fix paths for unpartitioned specs in writers (<a href="https://github.com/apache/iceberg/pull/7685">#7685</a>)</li>
<li>Fix OOM caused by Avro decoder caching (<a href="https://github.com/apache/iceberg/pull/7791">#7791</a>)</li>
<li>Spark</li>
<li>Added support for Spark 3.5<ul>
<li>Code for DELETE, UPDATE, and MERGE commands has moved to Spark, and all related extensions have been dropped from Iceberg.</li>
<li>Support for WHEN NOT MATCHED BY SOURCE clause in MERGE.</li>
<li>Column pruning in merge-on-read operations.</li>
<li>Ability to request a bigger advisory partition size for the final write to produce well-sized output files without harming the job parallelism.</li>
</ul>
</li>
<li>Dropped support for Spark 3.1</li>
<li>Deprecated support for Spark 3.2</li>
<li>Support vectorized reads for merge-on-read operations in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/8466">#8466</a>)</li>
<li>Increase default advisory partition size for writes in Spark 3.5 (<a href="https://github.com/apache/iceberg/pull/8660">#8660</a>)</li>
<li>Support distributed planning in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/8123">#8123</a>)</li>
<li>Support pushing down system functions by V2 filters in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/7886">#7886</a>)</li>
<li>Support fanout position delta writers in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/7703">#7703</a>)</li>
<li>Use fanout writers for unsorted tables by default in Spark 3.5 (<a href="https://github.com/apache/iceberg/pull/8621">#8621</a>)</li>
<li>Support multiple shuffle partitions per file in compaction in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/7897">#7897</a>)</li>
<li>Output net changes across snapshots for carryover rows in CDC (<a href="https://github.com/apache/iceberg/pull/7326">#7326</a>)</li>
<li>Display read metrics on Spark SQL UI (<a href="https://github.com/apache/iceberg/pull/7447">#7447</a>) (<a href="https://github.com/apache/iceberg/pull/8445">#8445</a>)</li>
<li>Adjust split size to benefit from cluster parallelism in Spark 3.4 and 3.5 (<a href="https://github.com/apache/iceberg/pull/7714">#7714</a>)</li>
<li>Add <code>fast_forward</code> procedure (<a href="https://github.com/apache/iceberg/pull/8081">#8081</a>)</li>
<li>Support filters when rewriting position deletes (<a href="https://github.com/apache/iceberg/pull/7582">#7582</a>)</li>
<li>Support setting current snapshot with ref (<a href="https://github.com/apache/iceberg/pull/8163">#8163</a>)</li>
<li>Make backup table name configurable during migration (<a href="https://github.com/apache/iceberg/pull/8227">#8227</a>)</li>
<li>Add write and SQL options to override compression config (<a href="https://github.com/apache/iceberg/pull/8313">#8313</a>)</li>
<li>Correct partition transform functions to match the spec (<a href="https://github.com/apache/iceberg/pull/8192">#8192</a>)</li>
<li>Enable extra commit properties with metadata delete (<a href="https://github.com/apache/iceberg/pull/7649">#7649</a>)</li>
<li>Flink</li>
<li>Add possibility of ordering the splits based on the file sequence number (<a href="https://github.com/apache/iceberg/pull/7661">#7661</a>)</li>
<li>Fix serialization in <code>TableSink</code> with anonymous object (<a href="https://github.com/apache/iceberg/pull/7866">#7866</a>)</li>
<li>Switch to <code>FileScanTaskParser</code> for JSON serialization of <code>IcebergSourceSplit</code> (<a href="https://github.com/apache/iceberg/pull/7978">#7978</a>)</li>
<li>Custom partitioner for bucket partitions (<a href="https://github.com/apache/iceberg/pull/7161">#7161</a>)</li>
<li>Implement data statistics coordinator to aggregate data statistics from operator subtasks (<a href="https://github.com/apache/iceberg/pull/7360">#7360</a>)</li>
<li>Support alter table column (<a href="https://github.com/apache/iceberg/pull/7628">#7628</a>)</li>
<li>Parquet</li>
<li>Add encryption config to read and write builders (<a href="https://github.com/apache/iceberg/pull/2639">#2639</a>)</li>
<li>Skip writing bloom filters for deletes (<a href="https://github.com/apache/iceberg/pull/7617">#7617</a>)</li>
<li>Cache codecs by name and level (<a href="https://github.com/apache/iceberg/pull/8182">#8182</a>)</li>
<li>Fix decimal data reading from <code>ParquetAvroValueReaders</code> (<a href="https://github.com/apache/iceberg/pull/8246">#8246</a>)</li>
<li>Handle filters with transforms by assuming data must be scanned (<a href="https://github.com/apache/iceberg/pull/8243">#8243</a>)</li>
<li>ORC</li>
<li>Handle filters with transforms by assuming the filter matches (<a href="https://github.com/apache/iceberg/pull/8244">#8244</a>)</li>
<li>Vendor Integrations </li>
<li>GCP: Fix single byte read in <code>GCSInputStream</code> (<a href="https://github.com/apache/iceberg/pull/8071">#8071</a>)</li>
<li>GCP: Add properties for OAtuh2 and update library (<a href="https://github.com/apache/iceberg/pull/8073">#8073</a>)</li>
<li>GCP: Add prefix and bulk operations to <code>GCSFileIO</code> (<a href="https://github.com/apache/iceberg/pull/8168">#8168</a>)</li>
<li>GCP: Add bundle jar for GCP-related dependencies (<a href="https://github.com/apache/iceberg/pull/8231">#8231</a>)</li>
<li>GCP: Add range reads to <code>GCSInputStream</code> (<a href="https://github.com/apache/iceberg/pull/8301">#8301</a>)</li>
<li>AWS: Add bundle jar for AWS-related dependencies (<a href="https://github.com/apache/iceberg/pull/8261">#8261</a>)</li>
<li>AWS: support config storage class for <code>S3FileIO</code> (<a href="https://github.com/apache/iceberg/pull/8154">#8154</a>)</li>
<li>AWS: Add <code>FileIO</code> tracker/closer to Glue catalog (<a href="https://github.com/apache/iceberg/pull/8315">#8315</a>)</li>
<li>AWS: Update S3 signer spec to allow an optional string body in <code>S3SignRequest</code> (<a href="https://github.com/apache/iceberg/pull/8361">#8361</a>)</li>
<li>Azure: Add <code>FileIO</code> that supports ADLSv2 storage (<a href="https://github.com/apache/iceberg/pull/8303">#8303</a>)</li>
<li>Azure: Make <code>ADLSFileIO</code> implement <code>DelegateFileIO</code> (<a href="https://github.com/apache/iceberg/pull/8563">#8563</a>)</li>
<li>Nessie: Provide better commit message on table registration (<a href="https://github.com/apache/iceberg/pull/8385">#8385</a>)</li>
<li>Dependencies</li>
<li>Bump Nessie to 0.71.0</li>
<li>Bump ORC to 1.9.1</li>
<li>Bump Arrow to 12.0.1</li>
<li>Bump AWS Java SDK to 2.20.131</li>
</ul>
<h3 id="131-release">1.3.1 release<a class="headerlink" href="#131-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.3.1 was released on July 25, 2023.
The 1.3.1 release addresses various issues identified in the 1.3.0 release.</p>
<ul>
<li>Core</li>
<li>Table Metadata parser now accepts null for fields: current-snapshot-id, properties, and snapshots (<a href="https://github.com/apache/iceberg/pull/8064">#8064</a>)</li>
<li>Hive</li>
<li>Fix HiveCatalog deleting metadata on failures in checking lock status (<a href="https://github.com/apache/iceberg/pull/7931">#7931</a>)</li>
<li>Spark</li>
<li>Fix RewritePositionDeleteFiles failure for certain partition types (<a href="https://github.com/apache/iceberg/pull/8059">#8059</a>)</li>
<li>Fix RewriteDataFiles concurrency edge-case on commit timeouts (<a href="https://github.com/apache/iceberg/pull/7933">#7933</a>)</li>
<li>Fix partition-level DELETE operations for WAP branches (<a href="https://github.com/apache/iceberg/pull/7900">#7900</a>)</li>
<li>Flink</li>
<li>FlinkCatalog creation no longer creates the default database (<a href="https://github.com/apache/iceberg/pull/8039">#8039</a>)</li>
</ul>
<h3 id="130-release">1.3.0 release<a class="headerlink" href="#130-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.3.0 was released on May 30th, 2023.
The 1.3.0 release adds a variety of new features and bug fixes.</p>
<ul>
<li>Core</li>
<li>Expose file and data sequence numbers in ContentFile (<a href="https://github.com/apache/iceberg/pull/7555">#7555</a>)</li>
<li>Improve bit density in object storage layout (<a href="https://github.com/apache/iceberg/pull/7128">#7128</a>)</li>
<li>Store split offsets for delete files (<a href="https://github.com/apache/iceberg/pull/7011">#7011</a>)</li>
<li>Readable metrics in entries metadata table (<a href="https://github.com/apache/iceberg/pull/7539">#7539</a>)</li>
<li>Delete file stats in partitions metadata table (<a href="https://github.com/apache/iceberg/pull/6661">#6661</a>)</li>
<li>Optimized vectorized reads for Parquet Decimal (<a href="https://github.com/apache/iceberg/pull/3249">#3249</a>)</li>
<li>Vectorized reads for Parquet INT96 timestamps in imported data (<a href="https://github.com/apache/iceberg/pull/6962">#6962</a>)</li>
<li>Support selected vector with ORC row and batch readers (<a href="https://github.com/apache/iceberg/pull/7197">#7197</a>)</li>
<li>Clean up expired metastore clients (<a href="https://github.com/apache/iceberg/pull/7310">#7310</a>)</li>
<li>Support for deleting old partition spec columns in V1 tables (<a href="https://github.com/apache/iceberg/pull/7398">#7398</a>)</li>
<li>Spark</li>
<li>Initial support for Spark 3.4</li>
<li>Removed integration for Spark 2.4</li>
<li>Support for storage-partitioned joins with mismatching keys in Spark 3.4 (MERGE commands) (<a href="https://github.com/apache/iceberg/pull/7424">#7424</a>)</li>
<li>Support for TimestampNTZ in Spark 3.4 (<a href="https://github.com/apache/iceberg/pull/7553">#7553</a>)</li>
<li>Ability to handle skew during writes in Spark 3.4 (<a href="https://github.com/apache/iceberg/pull/7520">#7520</a>)</li>
<li>Ability to coalesce small tasks during writes in Spark 3.4 (<a href="https://github.com/apache/iceberg/pull/7532">#7532</a>)</li>
<li>Distribution and ordering enhancements in Spark 3.4 (<a href="https://github.com/apache/iceberg/pull/7637">#7637</a>)</li>
<li>Action for rewriting position deletes (<a href="https://github.com/apache/iceberg/pull/7389">#7389</a>)</li>
<li>Procedure for rewriting position deletes (<a href="https://github.com/apache/iceberg/pull/7572">#7572</a>)</li>
<li>Avoid local sort for MERGE cardinality check (<a href="https://github.com/apache/iceberg/pull/7558">#7558</a>)</li>
<li>Support for rate limits in Structured Streaming (<a href="https://github.com/apache/iceberg/pull/4479">#4479</a>)</li>
<li>Read and write support for UUIDs (<a href="https://github.com/apache/iceberg/pull/7399">#7399</a>)</li>
<li>Concurrent compaction is enabled by default (<a href="https://github.com/apache/iceberg/pull/6907">#6907</a>)</li>
<li>Support for metadata columns in changelog tables (<a href="https://github.com/apache/iceberg/pull/7152">#7152</a>)</li>
<li>Add file group failure info for data compaction (<a href="https://github.com/apache/iceberg/pull/7361">#7361</a>)</li>
<li>Flink</li>
<li>Initial support for Flink 1.17</li>
<li>Removed integration for Flink 1.14</li>
<li>Data statistics operator to collect traffic distribution for guiding smart shuffling (<a href="https://github.com/apache/iceberg/pull/6382">#6382</a>)</li>
<li>Data statistics operator sends local data statistics to coordinator and receives aggregated data statistics from coordinator for smart shuffling (<a href="https://github.com/apache/iceberg/pull/7269">#7269</a>)</li>
<li>Exposed write parallelism in SQL hints (<a href="https://github.com/apache/iceberg/pull/7039">#7039</a>)</li>
<li>Row-level filtering (<a href="https://github.com/apache/iceberg/pull/7109">#7109</a>)</li>
<li>Use starting sequence number by default when rewriting data files (<a href="https://github.com/apache/iceberg/pull/7218">#7218</a>)</li>
<li>Config for max allowed consecutive planning failures in IcebergSource before failing the job (<a href="https://github.com/apache/iceberg/pull/7571">#7571</a>)</li>
<li>Vendor Integrations</li>
<li>AWS: Use Apache HTTP client as default AWS HTTP client (<a href="https://github.com/apache/iceberg/pull/7119">#7119</a>)</li>
<li>AWS: Prevent token refresh scheduling on every sign request (<a href="https://github.com/apache/iceberg/pull/7270">#7270</a>)</li>
<li>AWS: Disable local credentials if remote signing is enabled (<a href="https://github.com/apache/iceberg/pull/7230">#7230</a>)</li>
<li>Dependencies</li>
<li>Bump Arrow to 12.0.0</li>
<li>Bump ORC to 1.8.3</li>
<li>Bump Parquet to 1.13.1</li>
<li>Bump Nessie to 0.59.0</li>
</ul>
<h3 id="121-release">1.2.1 release<a class="headerlink" href="#121-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.2.1 was released on April 11th, 2023.
The 1.2.1 release is a patch release to address various issues identified in the prior release.
Here is an overview:</p>
<ul>
<li>CORE</li>
<li>REST: fix previous locations for refs-only load <a href="https://github.com/apache/iceberg/pull/7284">#7284</a></li>
<li>Parse snapshot-id as long in remove-statistics update <a href="https://github.com/apache/iceberg/pull/7235">#7235</a></li>
<li>Spark</li>
<li>Broadcast table instead of file IO in rewrite manifests <a href="https://github.com/apache/iceberg/pull/7263">#7263</a></li>
<li>Revert "Spark: Add "Iceberg" prefix to SparkTable name string for SparkUI <a href="https://github.com/apache/iceberg/pull/7273">#7273</a></li>
<li>AWS</li>
<li>Make AuthSession cache static <a href="https://github.com/apache/iceberg/pull/7289">#7289</a></li>
<li>Abort S3 input stream on close if not EOS <a href="https://github.com/apache/iceberg/pull/7262">#7262</a></li>
<li>Disable local credentials if remote signing is enabled <a href="https://github.com/apache/iceberg/pull/7230">#7230</a></li>
<li>Prevent token refresh scheduling on every sign request <a href="https://github.com/apache/iceberg/pull/7270">#7270</a></li>
<li>S3 Credentials provider support in DefaultAwsClientFactory <a href="https://github.com/apache/iceberg/pull/7066">#7066</a></li>
</ul>
<h3 id="120-release">1.2.0 release<a class="headerlink" href="#120-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.2.0 was released on March 20th, 2023.
The 1.2.0 release adds a variety of new features and bug fixes.
Here is an overview:</p>
<ul>
<li>Core</li>
<li>Added AES GCM encrpytion stream spec (<a href="https://github.com/apache/iceberg/pull/5432">#5432</a>)</li>
<li>Added support for Delta Lake to Iceberg table conversion (<a href="https://github.com/apache/iceberg/pull/6449">#6449</a>, <a href="https://github.com/apache/iceberg/pull/6880">#6880</a>)</li>
<li>Added support for <code>position_deletes</code> metadata table (<a href="https://github.com/apache/iceberg/pull/6365">#6365</a>, <a href="https://github.com/apache/iceberg/pull/6716">#6716</a>)</li>
<li>Added support for scan and commit metrics reporter that is pluggable through catalog (<a href="https://github.com/apache/iceberg/pull/6404">#6404</a>, <a href="https://github.com/apache/iceberg/pull/6246">#6246</a>, <a href="https://github.com/apache/iceberg/pull/6410">#6410</a>) </li>
<li>Added support for branch commit for all operations (<a href="https://github.com/apache/iceberg/pull/4926">#4926</a>, <a href="https://github.com/apache/iceberg/pull/5010">#5010</a>)</li>
<li>Added <code>FileIO</code> support for ORC readers and writers (<a href="https://github.com/apache/iceberg/pull/6293">#6293</a>)</li>
<li>Updated all actions to leverage bulk delete whenever possible (<a href="https://github.com/apache/iceberg/pull/6682">#6682</a>)</li>
<li>Updated snapshot ID definition in Puffin spec to support statistics file reuse (<a href="https://github.com/apache/iceberg/pull/6267">#6272</a>)</li>
<li>Added human-readable metrics information in <code>files</code> metadata table (<a href="https://github.com/apache/iceberg/pull/5376">#5376</a>)</li>
<li>Fixed incorrect Parquet row group skipping when min and max values are <code>NaN</code> (<a href="https://github.com/apache/iceberg/pull/6517">#6517</a>)</li>
<li>Fixed a bug that location provider could generate paths with double slash (<code>//</code>) which is not compatible in a Hadoop file system (<a href="https://github.com/apache/iceberg/pull/6777">#6777</a>)</li>
<li>Fixed metadata table time travel failure for tables that performed schema evolution (<a href="https://github.com/apache/iceberg/pull/6980">#6980</a>)</li>
<li>Spark</li>
<li>Added time range query support for changelog table (<a href="https://github.com/apache/iceberg/pull/6350">#6350</a>)</li>
<li>Added changelog view procedure for v1 table (<a href="https://github.com/apache/iceberg/pull/6012">#6012</a>)</li>
<li>Added support for storage partition joins to improve read and write performance (<a href="https://github.com/apache/iceberg/pull/6371">#6371</a>)</li>
<li>Updated default Arrow environment settings to improve read performance (<a href="https://github.com/apache/iceberg/pull/6550">#6550</a>)</li>
<li>Added aggregate pushdown support for <code>min</code>, <code>max</code> and <code>count</code> to improve read performance (<a href="https://github.com/apache/iceberg/pull/6622">#6622</a>)</li>
<li>Updated default distribution mode settings to improve write performance (<a href="https://github.com/apache/iceberg/pull/6828">#6828</a>, <a href="https://github.com/apache/iceberg/pull/6838">#6838</a>)</li>
<li>Updated DELETE to perform metadata-only update whenever possible to improve write performance (<a href="https://github.com/apache/iceberg/pull/6899">#6899</a>)</li>
<li>Improved predicate pushdown support for write operations (<a href="https://github.com/apache/iceberg/pull/6633">#6636</a>)</li>
<li>Added support for reading a branch or tag through table identifier and <code>VERSION AS OF</code> (a.k.a. <code>FOR SYSTEM_VERSION AS OF</code>) SQL syntax (<a href="https://github.com/apache/iceberg/pull/6717">#6717</a>, <a href="https://github.com/apache/iceberg/pull/6575">#6575</a>)</li>
<li>Added support for writing to a branch through identifier or through write-audit-publish (WAP) workflow settings (<a href="https://github.com/apache/iceberg/pull/6965">#6965</a>, <a href="https://github.com/apache/iceberg/pull/7050">#7050</a>)</li>
<li>Added DDL SQL extensions to create, replace and drop a branch or tag (<a href="https://github.com/apache/iceberg/pull/6638">#6638</a>, <a href="https://github.com/apache/iceberg/pull/6637">#6637</a>, <a href="https://github.com/apache/iceberg/pull/6752">#6752</a>, <a href="https://github.com/apache/iceberg/pull/6807">#6807</a>)</li>
<li>Added UDFs for <code>years</code>, <code>months</code>, <code>days</code> and <code>hours</code> transforms (<a href="https://github.com/apache/iceberg/pull/6207">#6207</a>, <a href="https://github.com/apache/iceberg/pull/6261">#6261</a>, <a href="https://github.com/apache/iceberg/pull/6300">#6300</a>, <a href="https://github.com/apache/iceberg/pull/6339">#6339</a>)</li>
<li>Added partition related stats for <code>add_files</code> procedure result (<a href="https://github.com/apache/iceberg/pull/6797">#6797</a>)</li>
<li>Fixed a bug that <code>rewrite_manifests</code> procedure produced a new manifest even when there was no rewrite performed (<a href="https://github.com/apache/iceberg/pull/6695">#6659</a>)</li>
<li>Fixed a bug that statistics files were not cleaned up in <code>expire_snapshots</code> procedure (<a href="https://github.com/apache/iceberg/pull/6090">#6090</a>)</li>
<li>Flink</li>
<li>Added support for metadata tables (<a href="https://github.com/apache/iceberg/pull/6222">#6222</a>)</li>
<li>Added support for read options in Flink source (<a href="https://github.com/apache/iceberg/pull/5967">#5967</a>)</li>
<li>Added support for reading and writing Avro <code>GenericRecord</code> (<a href="https://github.com/apache/iceberg/pull/6557">#6557</a>, <a href="https://github.com/apache/iceberg/pull/6584">#6584</a>)</li>
<li>Added support for reading a branch or tag and write to a branch (<a href="https://github.com/apache/iceberg/pull/6660">#6660</a>, <a href="https://github.com/apache/iceberg/pull/5029">#5029</a>)</li>
<li>Added throttling support for streaming read (<a href="https://github.com/apache/iceberg/pull/6299">#6299</a>)</li>
<li>Added support for multiple sinks for the same table in the same job (<a href="https://github.com/apache/iceberg/pull/6528">#6528</a>)</li>
<li>Fixed a bug that metrics config was not applied to equality and position deletes (<a href="https://github.com/apache/iceberg/pull/6271">#6271</a>, <a href="https://github.com/apache/iceberg/pull/6313">#6313</a>)</li>
<li>Vendor Integrations</li>
<li>Added Snowflake catalog integration (<a href="https://github.com/apache/iceberg/pull/6428">#6428</a>)</li>
<li>Added AWS sigV4 authentication support for REST catalog (<a href="https://github.com/apache/iceberg/pull/6951">#6951</a>)</li>
<li>Added support for AWS S3 remote signing (<a href="https://github.com/apache/iceberg/pull/6169">#6169</a>, <a href="https://github.com/apache/iceberg/pull/6835">#6835</a>, <a href="https://github.com/apache/iceberg/pull/7080">#7080</a>)</li>
<li>Updated AWS Glue catalog to skip table version archive by default (<a href="https://github.com/apache/iceberg/pull/6916">#6919</a>)</li>
<li>Updated AWS Glue catalog to not require a warehouse location (<a href="https://github.com/apache/iceberg/pull/6586">#6586</a>)</li>
<li>Fixed a bug that a bucket-only AWS S3 location such as <code>s3://my-bucket</code> could not be parsed (<a href="https://github.com/apache/iceberg/pull/6352">#6352</a>)</li>
<li>Fixed a bug that unnecessary HTTP client dependencies had to be included to use any AWS integration (<a href="https://github.com/apache/iceberg/pull/6746">#6746</a>)</li>
<li>Fixed a bug that AWS Glue catalog did not respect custom catalog ID when determining default warehouse location (<a href="https://github.com/apache/iceberg/pull/6223">#6223</a>)</li>
<li>Fixes a bug that AWS DynamoDB catalog namespace listing result was incomplete (<a href="https://github.com/apache/iceberg/pull/6823">#6823</a>)</li>
<li>Dependencies</li>
<li>Upgraded ORC to 1.8.1 (<a href="https://github.com/apache/iceberg/pull/6349">#6349</a>)</li>
<li>Upgraded Jackson to 2.14.1 (<a href="https://github.com/apache/iceberg/pull/6168">#6168</a>)</li>
<li>Upgraded AWS SDK V2 to 2.20.18 (<a href="https://github.com/apache/iceberg/pull/7003">#7003</a>)</li>
<li>Upgraded Nessie to 0.50.0 (<a href="https://github.com/apache/iceberg/pull/6875">#6875</a>)</li>
</ul>
<p>For more details, please visit <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-1.2.0">Github</a>.</p>
<h3 id="110-release">1.1.0 release<a class="headerlink" href="#110-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 1.1.0 was released on November 28th, 2022.
The 1.1.0 release deprecates various pre-1.0.0 methods,
and adds a variety of new features.
Here is an overview:</p>
<ul>
<li>Core</li>
<li>Puffin statistics have been <a href="https://github.com/apache/iceberg/pull/4945">added to the Table API</a></li>
<li>Support for <a href="https://github.com/apache/iceberg/pull/5268">Table scan reporting</a>, which enables collection of statistics of the table scans.</li>
<li><a href="https://github.com/apache/iceberg/pull/6002">Add file sequence number to ManifestEntry</a></li>
<li><a href="https://github.com/apache/iceberg/pull/5037">Support register table</a> for all the catalogs (previously it was only for Hive)</li>
<li><a href="https://github.com/apache/iceberg/pull/5618">Support performing merge appends and delete files on branches</a></li>
<li><a href="https://github.com/apache/iceberg/pull/5669">Improved Expire Snapshots FileCleanupStrategy</a></li>
<li><a href="https://github.com/apache/iceberg/pull/4926">SnapshotProducer supports branch writes</a></li>
<li>Spark</li>
<li><a href="https://github.com/apache/iceberg/pull/5961">Support for aggregate expressions</a></li>
<li><a href="https://github.com/apache/iceberg/pull/5740">SparkChangelogTable for querying changelogs</a></li>
<li>Dropped support for Apache Spark 3.0</li>
<li>Flink</li>
<li><a href="https://github.com/apache/iceberg/pull/5318">FLIP-27 reader is supported in SQL</a></li>
<li>Added support for Flink 1.16, dropped support for Flink 1.13</li>
<li>Dependencies</li>
<li><a href="https://github.com/apache/iceberg/pull/5612">AWS SDK: 2.17.257</a></li>
<li><a href="https://github.com/apache/iceberg/pull/6008">Nessie: 0.44</a></li>
<li><a href="https://github.com/apache/iceberg/pull/5699">Apache ORC: 1.8.0</a> (Also, supports <a href="https://github.com/apache/iceberg/pull/5313/files">setting bloom filters on row groups</a>)</li>
</ul>
<p>For more details, please visit <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-1.1.0">Github</a>.</p>
<h3 id="100-release">1.0.0 release<a class="headerlink" href="#100-release" title="Permanent link">🔗</a></h3>
<p>The 1.0.0 release officially guarantees the stability of the Iceberg API.</p>
<p>Iceberg's API has been largely stable since very early releases and has been integrated with many processing engines, but was still released under a 0.y.z version number indicating that breaking changes may happen. From 1.0.0 forward, the project will follow semver in the public API module, iceberg-api.</p>
<p>This release removes deprecated APIs that are no longer part of the API. To make transitioning to the new release easier, it is based on the 0.14.1 release with only important bug fixes:</p>
<ul>
<li>Increase metrics limit to 100 columns (<a href="https://github.com/apache/iceberg/pull/5933">#5933</a>)</li>
<li>Bump Spark patch versions for CVE-2022-33891 (<a href="https://github.com/apache/iceberg/pull/5292">#5292</a>)</li>
<li>Exclude Scala from Spark runtime Jars (<a href="https://github.com/apache/iceberg/pull/5884">#5884</a>)</li>
</ul>
<h3 id="0141-release">0.14.1 release<a class="headerlink" href="#0141-release" title="Permanent link">🔗</a></h3>
<p>This release includes all bug fixes from the 0.14.x patch releases.</p>
<h4 id="notable-bug-fixes">Notable bug fixes<a class="headerlink" href="#notable-bug-fixes" title="Permanent link">🔗</a></h4>
<ul>
<li>API</li>
<li>API: Fix ID assignment in schema merging (<a href="https://github.com/apache/iceberg/pull/5395">#5395</a>)</li>
<li>Core</li>
<li>Core: Fix snapshot log with intermediate transaction snapshots (<a href="https://github.com/apache/iceberg/pull/5568">#5568</a>)</li>
<li>Core: Fix exception handling in BaseTaskWriter (<a href="https://github.com/apache/iceberg/pull/5683">#5683</a>)</li>
<li>Core: Support deleting tables without metadata files (<a href="https://github.com/apache/iceberg/pull/5510">#5510</a>)</li>
<li>Core: Add CommitStateUnknownException handling to REST (<a href="https://github.com/apache/iceberg/pull/5694">#5694</a>)</li>
<li>Spark</li>
<li>Spark: Fix stats in rewrite metadata action (<a href="https://github.com/apache/iceberg/pull/5691">#5691</a>)</li>
<li>File Formats</li>
<li>Parquet: Close zstd input stream early to avoid memory pressure (<a href="https://github.com/apache/iceberg/pull/5681">#5681</a>)</li>
<li>Vendor Integrations</li>
<li>Core, AWS: Fix Kryo serialization failure for FileIO (<a href="https://github.com/apache/iceberg/pull/5437">#5437</a>)</li>
<li>AWS: S3OutputStream - failure to close should persist on subsequent close calls (<a href="https://github.com/apache/iceberg/pull/5311">#5311</a>)</li>
</ul>
<h3 id="0140-release">0.14.0 release<a class="headerlink" href="#0140-release" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.14.0 was released on 16 July 2022.</p>
<h4 id="highlights">Highlights<a class="headerlink" href="#highlights" title="Permanent link">🔗</a></h4>
<ul>
<li>Added several <a href="#performance-improvements">performance improvements</a> for scan planning and Spark queries</li>
<li>Added a common REST catalog client that uses change-based commits to resolve commit conflicts on the service side</li>
<li>Added support for Spark 3.3, including <code>AS OF</code> syntax for SQL time travel queries</li>
<li>Added support for Scala 2.13 with Spark 3.2 or later</li>
<li>Added merge-on-read support for MERGE and UPDATE queries in Spark 3.2 or later</li>
<li>Added support to rewrite partitions using zorder</li>
<li>Added support for Flink 1.15 and dropped support for Flink 1.12</li>
<li>Added a spec and implementation for Puffin, a format for large stats and index blobs, like <a href="https://datasketches.apache.org/docs/Theta/InverseEstimate.html">Theta sketches</a> or bloom filters</li>
<li>Added new interfaces for consuming data incrementally (both append and changelog scans)</li>
<li>Added support for bulk operations and ranged reads to FileIO interfaces</li>
<li>Added more metadata tables to show delete files in the metadata tree</li>
</ul>
<h4 id="high-level-features">High-level features<a class="headerlink" href="#high-level-features" title="Permanent link">🔗</a></h4>
<ul>
<li>API</li>
<li>Added IcebergBuild to expose Iceberg version and build information</li>
<li>Added binary compatibility checking to the build (<a href="https://github.com/apache/iceberg/pull/4638">#4638</a>, <a href="https://github.com/apache/iceberg/pull/4798">#4798</a>)</li>
<li>Added a new IncrementalAppendScan interface and planner implementation (<a href="https://github.com/apache/iceberg/pull/4580">#4580</a>)</li>
<li>Added a new IncrementalChangelogScan interface (<a href="https://github.com/apache/iceberg/pull/4870">#4870</a>)</li>
<li>Refactored the ScanTask hierarchy to create new task types for changelog scans (<a href="https://github.com/apache/iceberg/pull/5077">#5077</a>)</li>
<li>Added expression sanitizer (<a href="https://github.com/apache/iceberg/pull/4672">#4672</a>)</li>
<li>Added utility to check expression equivalence (<a href="https://github.com/apache/iceberg/pull/4947">#4947</a>)</li>
<li>Added support for serializing FileIO instances using initialization properties (<a href="https://github.com/apache/iceberg/pull/5178">#5178</a>)</li>
<li>Updated Snapshot methods to accept a FileIO to read metadata files, deprecated old methods (<a href="https://github.com/apache/iceberg/pull/4873">#4873</a>)</li>
<li>Added optional interfaces to FileIO, for batch deletes (<a href="https://github.com/apache/iceberg/pull/4052">#4052</a>), prefix operations (<a href="https://github.com/apache/iceberg/pull/5096">#5096</a>), and ranged reads (<a href="https://github.com/apache/iceberg/pull/4608">#4608</a>)</li>
<li>Core</li>
<li>Added a common client for REST-based catalog services that uses a change-based protocol (<a href="https://github.com/apache/iceberg/pull/4320">#4320</a>, <a href="https://github.com/apache/iceberg/pull/4319">#4319</a>)</li>
<li>Added Puffin, a file format for statistics and index payloads or sketches (<a href="https://github.com/apache/iceberg/pull/4944">#4944</a>, <a href="https://github.com/apache/iceberg/pull/4537">#4537</a>)</li>
<li>Added snapshot references to track tags and branches (<a href="https://github.com/apache/iceberg/pull/4019">#4019</a>)</li>
<li>ManageSnapshots now supports multiple operations using transactions, and added branch and tag operations (<a href="https://github.com/apache/iceberg/pull/4128">#4128</a>, <a href="https://github.com/apache/iceberg/pull/4071">#4071</a>)</li>
<li>ReplacePartitions and OverwriteFiles now support serializable isolation (<a href="https://github.com/apache/iceberg/pull/2925">#2925</a>, <a href="https://github.com/apache/iceberg/pull/4052">#4052</a>)</li>
<li>Added new metadata tables: <code>data_files</code> (<a href="https://github.com/apache/iceberg/pull/4336">#4336</a>), <code>delete_files</code> (<a href="https://github.com/apache/iceberg/pull/4243">#4243</a>), <code>all_delete_files</code>, and <code>all_files</code> (<a href="https://github.com/apache/iceberg/pull/4694">#4694</a>)</li>
<li>Added deleted files to the <code>files</code> metadata table (<a href="https://github.com/apache/iceberg/pull/4336">#4336</a>) and delete file counts to the <code>manifests</code> table (<a href="https://github.com/apache/iceberg/pull/4764">#4764</a>)</li>
<li>Added support for predicate pushdown for the <code>all_data_files</code> metadata table (<a href="https://github.com/apache/iceberg/pull/4382">#4382</a>) and the <code>all_manifests</code> table (<a href="https://github.com/apache/iceberg/pull/4736">#4736</a>)</li>
<li>Added support for catalogs to default table properties on creation (<a href="https://github.com/apache/iceberg/pull/4011">#4011</a>)</li>
<li>Updated sort order construction to ensure all partition fields are added to avoid partition closed failures (<a href="https://github.com/apache/iceberg/pull/5131">#5131</a>)</li>
<li>Spark</li>
<li>Spark 3.3 is now supported (<a href="https://github.com/apache/iceberg/pull/5056">#5056</a>)</li>
<li>Added SQL time travel using <code>AS OF</code> syntax in Spark 3.3 (<a href="https://github.com/apache/iceberg/pull/5156">#5156</a>)</li>
<li>Scala 2.13 is now supported for Spark 3.2 and 3.3 (<a href="https://github.com/apache/iceberg/pull/4009">#4009</a>)</li>
<li>Added support for the <code>mergeSchema</code> option for DataFrame writes (<a href="https://github.com/apache/iceberg/pull/4154">#4154</a>)</li>
<li>MERGE and UPDATE queries now support the lazy / merge-on-read strategy (<a href="https://github.com/apache/iceberg/pull/3984">#3984</a>, <a href="https://github.com/apache/iceberg/pull/4047">#4047</a>)</li>
<li>Added zorder rewrite strategy to the <code>rewrite_data_files</code> stored procedure and action (<a href="https://github.com/apache/iceberg/pull/3983">#3983</a>, <a href="https://github.com/apache/iceberg/pull/4902">#4902</a>)</li>
<li>Added a <code>register_table</code> stored procedure to create tables from metadata JSON files (<a href="https://github.com/apache/iceberg/pull/4810">#4810</a>)</li>
<li>Added a <code>publish_changes</code> stored procedure to publish staged commits by ID (<a href="https://github.com/apache/iceberg/pull/4715">#4715</a>)</li>
<li>Added <code>CommitMetadata</code> helper class to set snapshot summary properties from SQL (<a href="https://github.com/apache/iceberg/pull/4956">#4956</a>)</li>
<li>Added support to supply a file listing to remove orphan data files procedure and action (<a href="https://github.com/apache/iceberg/pull/4503">#4503</a>)</li>
<li>Added FileIO metrics to the Spark UI (<a href="https://github.com/apache/iceberg/pull/4030">#4030</a>, <a href="https://github.com/apache/iceberg/pull/4050">#4050</a>)</li>
<li>DROP TABLE now supports the PURGE flag (<a href="https://github.com/apache/iceberg/pull/3056">#3056</a>)</li>
<li>Added support for custom isolation level for dynamic partition overwrites (<a href="https://github.com/apache/iceberg/pull/2925">#2925</a>) and filter overwrites (<a href="https://github.com/apache/iceberg/pull/4293">#4293</a>)</li>
<li>Schema identifier fields are now shown in table properties (<a href="https://github.com/apache/iceberg/pull/4475">#4475</a>)</li>
<li>Abort cleanup now supports parallel execution (<a href="https://github.com/apache/iceberg/pull/4704">#4704</a>)</li>
<li>Flink</li>
<li>Flink 1.15 is now supported (<a href="https://github.com/apache/iceberg/pull/4553">#4553</a>)</li>
<li>Flink 1.12 support was removed (<a href="https://github.com/apache/iceberg/pull/4551">#4551</a>)</li>
<li>Added a FLIP-27 source and builder to 1.14 and 1.15 (<a href="https://github.com/apache/iceberg/pull/5109">#5109</a>)</li>
<li>Added an option to set the monitor interval (<a href="https://github.com/apache/iceberg/pull/4887">#4887</a>) and an option to limit the number of snapshots in a streaming read planning operation (<a href="https://github.com/apache/iceberg/pull/4943">#4943</a>)</li>
<li>Added support for write options, like <code>write-format</code> to Flink sink builder (<a href="https://github.com/apache/iceberg/pull/3998">#3998</a>)</li>
<li>Added support for task locality when reading from HDFS (<a href="https://github.com/apache/iceberg/pull/3817">#3817</a>)</li>
<li>Use Hadoop configuration files from <code>hadoop-conf-dir</code> property (<a href="https://github.com/apache/iceberg/pull/4622">#4622</a>)</li>
<li>Vendor integrations</li>
<li>Added Dell ECS integration (<a href="https://github.com/apache/iceberg/pull/3376">#3376</a>, <a href="https://github.com/apache/iceberg/pull/4221">#4221</a>)</li>
<li>JDBC catalog now supports namespace properties (<a href="https://github.com/apache/iceberg/pull/3275">#3275</a>)</li>
<li>AWS Glue catalog supports native Glue locking (<a href="https://github.com/apache/iceberg/pull/4166">#4166</a>)</li>
<li>AWS S3FileIO supports using S3 access points (<a href="https://github.com/apache/iceberg/pull/4334">#4334</a>), bulk operations (<a href="https://github.com/apache/iceberg/pull/4052">#4052</a>, <a href="https://github.com/apache/iceberg/pull/5096">#5096</a>), ranged reads (<a href="https://github.com/apache/iceberg/pull/4608">#4608</a>), and tagging at write time or in place of deletes (<a href="https://github.com/apache/iceberg/pull/4259">#4259</a>, <a href="https://github.com/apache/iceberg/pull/4342">#4342</a>)</li>
<li>AWS GlueCatalog supports passing LakeFormation credentials (<a href="https://github.com/apache/iceberg/pull/4280">#4280</a>) </li>
<li>AWS DynamoDB catalog and lock supports overriding the DynamoDB endpoint (<a href="https://github.com/apache/iceberg/pull/4726">#4726</a>)</li>
<li>Nessie now supports namespaces and namespace properties (<a href="https://github.com/apache/iceberg/pull/4385">#4385</a>, <a href="https://github.com/apache/iceberg/pull/4610">#4610</a>)</li>
<li>Nessie now passes most common catalog tests (<a href="https://github.com/apache/iceberg/pull/4392">#4392</a>)</li>
<li>Parquet</li>
<li>Added support for row group skipping using Parquet bloom filters (<a href="https://github.com/apache/iceberg/pull/4938">#4938</a>)</li>
<li>Added table configuration options for writing Parquet bloom filters (<a href="https://github.com/apache/iceberg/pull/5035">#5035</a>)</li>
<li>ORC</li>
<li>Support file rolling at a target file size (<a href="https://github.com/apache/iceberg/pull/4419">#4419</a>)</li>
<li>Support table compression settings, <code>write.orc.compression-codec</code> and <code>write.orc.compression-strategy</code> (<a href="https://github.com/apache/iceberg/pull/4273">#4273</a>)</li>
</ul>
<h4 id="performance-improvements">Performance improvements<a class="headerlink" href="#performance-improvements" title="Permanent link">🔗</a></h4>
<ul>
<li>Core</li>
<li>Fixed manifest file handling in scan planning to open manifests in the planning threadpool (<a href="https://github.com/apache/iceberg/pull/5206">#5206</a>)</li>
<li>Avoided an extra S3 HEAD request by passing file length when opening manifest files (<a href="https://github.com/apache/iceberg/pull/5207">#5207</a>)</li>
<li>Refactored Arrow vectorized readers to avoid extra dictionary copies (<a href="https://github.com/apache/iceberg/pull/5137">#5137</a>)</li>
<li>Improved Arrow decimal handling to improve decimal performance (<a href="https://github.com/apache/iceberg/pull/5168">#5168</a>, <a href="https://github.com/apache/iceberg/pull/5198">#5198</a>)</li>
<li>Added support for Avro files with Zstd compression (<a href="https://github.com/apache/iceberg/pull/4083">#4083</a>)</li>
<li>Column metrics are now disabled by default after the first 32 columns (<a href="https://github.com/apache/iceberg/pull/3959">#3959</a>, <a href="https://github.com/apache/iceberg/pull/5215">#5215</a>)</li>
<li>Updated delete filters to copy row wrappers to avoid expensive type analysis (<a href="https://github.com/apache/iceberg/pull/5249">#5249</a>)</li>
<li>Snapshot expiration supports parallel execution (<a href="https://github.com/apache/iceberg/pull/4148">#4148</a>)</li>
<li>Manifest updates can use a custom thread pool (<a href="https://github.com/apache/iceberg/pull/4146">#4146</a>)</li>
<li>Spark</li>
<li>Parquet vectorized reads are enabled by default (<a href="https://github.com/apache/iceberg/pull/4196">#4196</a>)</li>
<li>Scan statistics now adjust row counts for split data files (<a href="https://github.com/apache/iceberg/pull/4446">#4446</a>)</li>
<li>Implemented <code>SupportsReportStatistics</code> in <code>ScanBuilder</code> to work around SPARK-38962 (<a href="https://github.com/apache/iceberg/pull/5136">#5136</a>)</li>
<li>Updated Spark tables to avoid expensive (and inaccurate) size estimation (<a href="https://github.com/apache/iceberg/pull/5225">#5225</a>)</li>
<li>Flink</li>
<li>Operators will now use a worker pool per job (<a href="https://github.com/apache/iceberg/pull/4177">#4177</a>)</li>
<li>Fixed <code>ClassCastException</code> thrown when reading arrays from Parquet (<a href="https://github.com/apache/iceberg/pull/4432">#4432</a>)</li>
<li>Hive</li>
<li>Added vectorized Parquet reads for Hive 3 (<a href="https://github.com/apache/iceberg/pull/3980">#3980</a>)</li>
<li>Improved generic reader performance using copy instead of create (<a href="https://github.com/apache/iceberg/pull/4218">#4218</a>)</li>
</ul>
<h4 id="notable-bug-fixes_1">Notable bug fixes<a class="headerlink" href="#notable-bug-fixes_1" title="Permanent link">🔗</a></h4>
<p>This release includes all bug fixes from the 0.13.x patch releases.</p>
<ul>
<li>Core</li>
<li>Fixed an exception thrown when metadata-only deletes encounter delete files that are partially matched (<a href="https://github.com/apache/iceberg/pull/4304">#4304</a>)</li>
<li>Fixed transaction retries for changes without validations, like schema updates, that could ignore an update (<a href="https://github.com/apache/iceberg/pull/4464">#4464</a>)</li>
<li>Fixed failures when reading metadata tables with evolved partition specs (<a href="https://github.com/apache/iceberg/pull/4520">#4520</a>, <a href="https://github.com/apache/iceberg/pull/4560">#4560</a>)</li>
<li>Fixed delete files dropped when a manifest is rewritten following a format version upgrade (<a href="https://github.com/apache/iceberg/pull/4514">#4514</a>)</li>
<li>Fixed missing metadata files resulting from an OOM during commit cleanup (<a href="https://github.com/apache/iceberg/pull/4673">#4673</a>)</li>
<li>Updated logging to use sanitized expressions to avoid leaking values (<a href="https://github.com/apache/iceberg/pull/4672">#4672</a>)</li>
<li>Spark</li>
<li>Fixed Spark to skip calling abort when CommitStateUnknownException is thrown (<a href="https://github.com/apache/iceberg/pull/4687">#4687</a>)</li>
<li>Fixed MERGE commands with mixed case identifiers (<a href="https://github.com/apache/iceberg/pull/4848">#4848</a>)</li>
<li>Flink</li>
<li>Fixed table property update failures when tables have a primary key (<a href="https://github.com/apache/iceberg/pull/4561">#4561</a>)</li>
<li>Integrations</li>
<li>JDBC catalog behavior has been updated to pass common catalog tests (<a href="https://github.com/apache/iceberg/pull/4220">#4220</a>, <a href="https://github.com/apache/iceberg/pull/4231">#4231</a>)</li>
</ul>
<h4 id="dependency-changes">Dependency changes<a class="headerlink" href="#dependency-changes" title="Permanent link">🔗</a></h4>
<ul>
<li>Updated Apache Avro to 1.10.2 (previously 1.10.1)</li>
<li>Updated Apache Parquet to 1.12.3 (previously 1.12.2)</li>
<li>Updated Apache ORC to 1.7.5 (previously 1.7.2)</li>
<li>Updated Apache Arrow to 7.0.0 (previously 6.0.0)</li>
<li>Updated AWS SDK to 2.17.131 (previously 2.15.7)</li>
<li>Updated Nessie to 0.30.0 (previously 0.18.0)</li>
<li>Updated Caffeine to 2.9.3 (previously 2.8.4)</li>
</ul>
<h3 id="0132">0.13.2<a class="headerlink" href="#0132" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.13.2 was released on June 15th, 2022.</p>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.13.2">0.13.2</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.13.2/apache-iceberg-0.13.2.tar.gz">0.13.2 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.2/apache-iceberg-0.13.2.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.2/apache-iceberg-0.13.2.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.2_2.12/0.13.2/iceberg-spark-runtime-3.2_2.12-0.13.2.jar">0.13.2 Spark 3.2 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.1_2.12/0.13.2/iceberg-spark-runtime-3.1_2.12-0.13.2.jar">0.13.2 Spark 3.1 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.13.2/iceberg-spark3-runtime-0.13.2.jar">0.13.2 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.13.2/iceberg-spark-runtime-0.13.2.jar">0.13.2 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.14/0.13.2/iceberg-flink-runtime-1.14-0.13.2.jar">0.13.2 Flink 1.14 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.13/0.13.2/iceberg-flink-runtime-1.13-0.13.2.jar">0.13.2 Flink 1.13 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.12/0.13.2/iceberg-flink-runtime-1.12-0.13.2.jar">0.13.2 Flink 1.12 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.13.2/iceberg-hive-runtime-0.13.2.jar">0.13.2 Hive runtime Jar</a></li>
</ul>
<p><strong>Important bug fixes and changes:</strong></p>
<ul>
<li><strong>Core</strong></li>
<li><a href="https://github.com/apache/iceberg/pull/4673">#4673</a> fixes table corruption from OOM during commit cleanup</li>
<li><a href="https://github.com/apache/iceberg/pull/4514">#4514</a> row delta delete files were dropped in sequential commits after table format updated to v2</li>
<li><a href="https://github.com/apache/iceberg/pull/4464">#4464</a> fixes an issue were conflicting transactions have been ignored during a commit</li>
<li><a href="https://github.com/apache/iceberg/pull/4520">#4520</a> fixes an issue with wrong table predicate filtering with evolved partition specs</li>
<li><strong>Spark</strong></li>
<li><a href="https://github.com/apache/iceberg/pull/4663">#4663</a> fixes NPEs in Spark value converter</li>
<li><a href="https://github.com/apache/iceberg/pull/4687">#4687</a> fixes an issue with incorrect aborts when non-runtime exceptions were thrown in Spark</li>
<li><strong>Flink</strong></li>
<li>Note that there's a correctness issue when using upsert mode in Flink 1.12. Given that Flink 1.12 is deprecated, it was decided to not fix this bug but rather log a warning (see also <a href="https://github.com/apache/iceberg/pull/4754">#4754</a>).</li>
<li><strong>Nessie</strong></li>
<li><a href="https://github.com/apache/iceberg/pull/4509">#4509</a> fixes a NPE that occurred when accessing refreshed tables in NessieCatalog</li>
</ul>
<p>A more exhaustive list of changes is available under the <a href="https://github.com/apache/iceberg/milestone/18?closed=1">0.13.2 release milestone</a>.</p>
<h3 id="0131">0.13.1<a class="headerlink" href="#0131" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.13.1 was released on February 14th, 2022.</p>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.13.1">0.13.1</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.13.1/apache-iceberg-0.13.1.tar.gz">0.13.1 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.1/apache-iceberg-0.13.1.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.1/apache-iceberg-0.13.1.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.2_2.12/0.13.1/iceberg-spark-runtime-3.2_2.12-0.13.1.jar">0.13.1 Spark 3.2 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.1_2.12/0.13.1/iceberg-spark-runtime-3.1_2.12-0.13.1.jar">0.13.1 Spark 3.1 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.13.1/iceberg-spark3-runtime-0.13.1.jar">0.13.1 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.13.1/iceberg-spark-runtime-0.13.1.jar">0.13.1 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.14/0.13.1/iceberg-flink-runtime-1.14-0.13.1.jar">0.13.1 Flink 1.14 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.13/0.13.1/iceberg-flink-runtime-1.13-0.13.1.jar">0.13.1 Flink 1.13 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.12/0.13.1/iceberg-flink-runtime-1.12-0.13.1.jar">0.13.1 Flink 1.12 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.13.1/iceberg-hive-runtime-0.13.1.jar">0.13.1 Hive runtime Jar</a></li>
</ul>
<p><strong>Important bug fixes:</strong></p>
<ul>
<li><strong>Spark</strong></li>
<li><a href="https://github.com/apache/iceberg/pull/4023">#4023</a> fixes predicate pushdown in row-level operations for merge conditions in Spark 3.2.
Prior to the fix, filters would not be extracted and targeted merge conditions were not pushed down leading to degraded performance
for these targeted merge operations.</li>
<li>
<p><a href="https://github.com/apache/iceberg/pull/4024">#4024</a> fixes table creation in the root namespace of a Hadoop Catalog.</p>
</li>
<li>
<p><strong>Flink</strong></p>
</li>
<li><a href="https://github.com/apache/iceberg/pull/3986">#3986</a> fixes manifest location collisions when there are multiple committers
in the same Flink job.</li>
</ul>
<h3 id="0130">0.13.0<a class="headerlink" href="#0130" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.13.0 was released on February 4th, 2022.</p>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.13.0">0.13.0</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.13.0/apache-iceberg-0.13.0.tar.gz">0.13.0 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.0/apache-iceberg-0.13.0.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.13.0/apache-iceberg-0.13.0.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.2_2.12/0.13.0/iceberg-spark-runtime-3.2_2.12-0.13.0.jar">0.13.0 Spark 3.2 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime-3.1_2.12/0.13.0/iceberg-spark-runtime-3.1_2.12-0.13.0.jar">0.13.0 Spark 3.1 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.13.0/iceberg-spark3-runtime-0.13.0.jar">0.13.0 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.13.0/iceberg-spark-runtime-0.13.0.jar">0.13.0 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.14/0.13.0/iceberg-flink-runtime-1.14-0.13.0.jar">0.13.0 Flink 1.14 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.13/0.13.0/iceberg-flink-runtime-1.13-0.13.0.jar">0.13.0 Flink 1.13 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime-1.12/0.13.0/iceberg-flink-runtime-1.12-0.13.0.jar">0.13.0 Flink 1.12 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.13.0/iceberg-hive-runtime-0.13.0.jar">0.13.0 Hive runtime Jar</a></li>
</ul>
<p><strong>High-level features:</strong></p>
<ul>
<li><strong>Core</strong></li>
<li>Catalog caching now supports cache expiration through catalog property <code>cache.expiration-interval-ms</code> [<a href="https://github.com/apache/iceberg/pull/3543">#3543</a>]</li>
<li>Catalog now supports registration of Iceberg table from a given metadata file location [<a href="https://github.com/apache/iceberg/pull/3851">#3851</a>]</li>
<li>Hadoop catalog can be used with S3 and other file systems safely by using a lock manager [<a href="https://github.com/apache/iceberg/pull/3663">#3663</a>]</li>
<li><strong>Vendor Integrations</strong></li>
<li>Google Cloud Storage (GCS) <code>FileIO</code> is supported with optimized read and write using GCS streaming transfer [<a href="https://github.com/apache/iceberg/pull/3711">#3711</a>]</li>
<li>Aliyun Object Storage Service (OSS) <code>FileIO</code> is supported [<a href="https://github.com/apache/iceberg/pull/3553">#3553</a>]</li>
<li>Any S3-compatible storage (e.g. MinIO) can now be accessed through AWS <code>S3FileIO</code> with custom endpoint and credential configurations [<a href="https://github.com/apache/iceberg/pull/3656">#3656</a>] [<a href="https://github.com/apache/iceberg/pull/3658">#3658</a>]</li>
<li>AWS <code>S3FileIO</code> now supports server-side checksum validation [<a href="https://github.com/apache/iceberg/pull/3813">#3813</a>]</li>
<li>AWS <code>GlueCatalog</code> now displays more table information including table location, description [<a href="https://github.com/apache/iceberg/pull/3467">#3467</a>] and columns [<a href="https://github.com/apache/iceberg/pull/3888">#3888</a>]</li>
<li>Using multiple <code>FileIO</code>s based on file path scheme is supported by configuring a <code>ResolvingFileIO</code> [<a href="https://github.com/apache/iceberg/pull/3593">#3593</a>]</li>
<li><strong>Spark</strong></li>
<li>Spark 3.2 is supported [<a href="https://github.com/apache/iceberg/pull/3335">#3335</a>] with merge-on-read <code>DELETE</code> [<a href="https://github.com/apache/iceberg/pull/3970">#3970</a>]</li>
<li><code>RewriteDataFiles</code> action now supports sort-based table optimization [<a href="https://github.com/apache/iceberg/pull/2829">#2829</a>] and merge-on-read delete compaction [<a href="https://github.com/apache/iceberg/pull/3454">#3454</a>]. The corresponding Spark call procedure <code>rewrite_data_files</code> is also supported [<a href="https://github.com/apache/iceberg/pull/3375">#3375</a>]</li>
<li>Time travel queries now use snapshot schema instead of the table's latest schema [<a href="https://github.com/apache/iceberg/pull/3722">#3722</a>]</li>
<li>Spark vectorized reads now support row-level deletes [<a href="https://github.com/apache/iceberg/pull/3557">#3557</a>] [<a href="https://github.com/apache/iceberg/pull/3287">#3287</a>]</li>
<li><code>add_files</code> procedure now skips duplicated files by default (can be turned off with the <code>check_duplicate_files</code> flag) [<a href="https://github.com/apache/iceberg/issues/2779">#2895</a>], skips folder without file [<a href="https://github.com/apache/iceberg/issues/3455">#2895</a>] and partitions with <code>null</code> values [<a href="https://github.com/apache/iceberg/issues/3778">#2895</a>] instead of throwing exception, and supports partition pruning for faster table import [<a href="https://github.com/apache/iceberg/issues/3745">#3745</a>]</li>
<li><strong>Flink</strong></li>
<li>Flink 1.13 and 1.14 are supported [<a href="https://github.com/apache/iceberg/pull/3116">#3116</a>] [<a href="https://github.com/apache/iceberg/pull/3434">#3434</a>]</li>
<li>Flink connector support is supported [<a href="https://github.com/apache/iceberg/pull/2666">#2666</a>]</li>
<li>Upsert write option is supported [<a href="https://github.com/apache/iceberg/pull/2863">#2863</a>]</li>
<li><strong>Hive</strong></li>
<li>Table listing in Hive catalog can now skip non-Iceberg tables by disabling flag <code>list-all-tables</code> [<a href="https://github.com/apache/iceberg/pull/3908">#3908</a>]</li>
<li>Hive tables imported to Iceberg can now be read by <code>IcebergInputFormat</code> [<a href="https://github.com/apache/iceberg/pull/3312">#3312</a>]</li>
<li><strong>File Formats</strong></li>
<li>ORC now supports writing delete file [<a href="https://github.com/apache/iceberg/pull/3248">#3248</a>] [<a href="https://github.com/apache/iceberg/pull/3250">#3250</a>] [<a href="https://github.com/apache/iceberg/pull/3366">#3366</a>]</li>
</ul>
<p><strong>Important bug fixes:</strong></p>
<ul>
<li><strong>Core</strong></li>
<li>Iceberg new data file root path is configured through <code>write.data.path</code> going forward. <code>write.folder-storage.path</code> and <code>write.object-storage.path</code> are deprecated [<a href="https://github.com/apache/iceberg/pull/3094">#3094</a>]</li>
<li>Catalog commit status is <code>UNKNOWN</code> instead of <code>FAILURE</code> when new metadata location cannot be found in snapshot history [<a href="https://github.com/apache/iceberg/pull/3717">#3717</a>]</li>
<li>Dropping table now also deletes old metadata files instead of leaving them strained [<a href="https://github.com/apache/iceberg/pull/3622">#3622</a>]</li>
<li><code>history</code> and <code>snapshots</code> metadata tables can now query tables with no current snapshot instead of returning empty [<a href="https://github.com/apache/iceberg/pull/3812">#3812</a>]</li>
<li><strong>Vendor Integrations</strong></li>
<li>Using cloud service integrations such as AWS <code>GlueCatalog</code> and <code>S3FileIO</code> no longer fail when missing Hadoop dependencies in the execution environment [<a href="https://github.com/apache/iceberg/pull/3590">#3590</a>]</li>
<li>AWS clients are now auto-closed when related <code>FileIO</code> or <code>Catalog</code> is closed. There is no need to close the AWS clients separately [<a href="https://github.com/apache/iceberg/pull/2878">#2878</a>]</li>
<li><strong>Spark</strong></li>
<li>For Spark &gt;= 3.1, <code>REFRESH TABLE</code> can now be used with Spark session catalog instead of throwing exception [<a href="https://github.com/apache/iceberg/pull/3072">#3072</a>]</li>
<li>Insert overwrite mode now skips partition with 0 record instead of failing the write operation [<a href="https://github.com/apache/iceberg/issues/2895">#2895</a>]</li>
<li>Spark snapshot expiration action now supports custom <code>FileIO</code> instead of just <code>HadoopFileIO</code> [<a href="https://github.com/apache/iceberg/pull/3089">#3089</a>]</li>
<li><code>REPLACE TABLE AS SELECT</code> can now work with tables with columns that have changed partition transform. Each old partition field of the same column is converted to a void transform with a different name [<a href="https://github.com/apache/iceberg/issues/3421">#3421</a>]</li>
<li>Spark SQL filters containing binary or fixed literals can now be pushed down instead of throwing exception [<a href="https://github.com/apache/iceberg/pull/3728">#3728</a>]</li>
<li><strong>Flink</strong></li>
<li>A <code>ValidationException</code> will be thrown if a user configures both <code>catalog-type</code> and <code>catalog-impl</code>. Previously it chose to use <code>catalog-type</code>. The new behavior brings Flink consistent with Spark and Hive [<a href="https://github.com/apache/iceberg/issues/3308">#3308</a>]</li>
<li>Changelog tables can now be queried without <code>RowData</code> serialization issues [<a href="https://github.com/apache/iceberg/pull/3240">#3240</a>]</li>
<li><code>java.sql.Time</code> data type can now be written without data overflow problem [<a href="https://github.com/apache/iceberg/pull/3740">#3740</a>]</li>
<li>Avro position delete files can now be read without encountering <code>NullPointerException</code> [<a href="https://github.com/apache/iceberg/pull/3540">#3540</a>]</li>
<li><strong>Hive</strong></li>
<li>Hive catalog can now be initialized with a <code>null</code> Hadoop configuration instead of throwing exception [<a href="https://github.com/apache/iceberg/pull/3252">#3252</a>]</li>
<li>Table creation can now succeed instead of throwing exception when some columns do not have comments [<a href="https://github.com/apache/iceberg/pull/3531">#3531</a>]</li>
<li><strong>File Formats</strong></li>
<li>Parquet file writing issue is fixed for string data with over 16 unparseable chars (e.g. high/low surrogates) [<a href="https://github.com/apache/iceberg/pull/3760">#3760</a>]</li>
<li>ORC vectorized read is now configured using <code>read.orc.vectorization.batch-size</code> instead of <code>read.parquet.vectorization.batch-size</code> [<a href="https://github.com/apache/iceberg/pull/3133">#3133</a>]</li>
</ul>
<p><strong>Other notable changes:</strong></p>
<ul>
<li>The community has finalized the long-term strategy of Spark, Flink and Hive support. See <a href="../multi-engine-support/">Multi-Engine Support</a> page for more details.</li>
</ul>
<h3 id="0121">0.12.1<a class="headerlink" href="#0121" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.12.1 was released on November 8th, 2021.</p>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.12.1">0.12.1</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.12.1/apache-iceberg-0.12.1.tar.gz">0.12.1 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.12.1/apache-iceberg-0.12.1.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.12.1/apache-iceberg-0.12.1.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.12.1/iceberg-spark3-runtime-0.12.1.jar">0.12.1 Spark 3.x runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.12.1/iceberg-spark-runtime-0.12.1.jar">0.12.1 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime/0.12.1/iceberg-flink-runtime-0.12.1.jar">0.12.1 Flink runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.12.1/iceberg-hive-runtime-0.12.1.jar">0.12.1 Hive runtime Jar</a></li>
</ul>
<p>Important bug fixes and changes:</p>
<ul>
<li><a href="https://github.com/apache/iceberg/pull/3258">#3264</a> fixes validation failures that occurred after snapshot expiration when writing Flink CDC streams to Iceberg tables.</li>
<li><a href="https://github.com/apache/iceberg/pull/3264">#3264</a> fixes reading projected map columns from Parquet files written before Parquet 1.11.1.</li>
<li><a href="https://github.com/apache/iceberg/pull/3195">#3195</a> allows validating that commits that produce row-level deltas don't conflict with concurrently added files. Ensures users can maintain serializable isolation for update and delete operations, including merge operations.</li>
<li><a href="https://github.com/apache/iceberg/pull/3199">#3199</a> allows validating that commits that overwrite files don't conflict with concurrently added files. Ensures users can maintain serializable isolation for overwrite operations.</li>
<li><a href="https://github.com/apache/iceberg/pull/3135">#3135</a> fixes equality-deletes using <code>DATE</code>, <code>TIMESTAMP</code>, and <code>TIME</code> types.</li>
<li><a href="https://github.com/apache/iceberg/pull/3078">#3078</a> prevents the JDBC catalog from overwriting the <code>jdbc.user</code> property if any property called user exists in the environment.</li>
<li><a href="https://github.com/apache/iceberg/pull/3035">#3035</a> fixes drop namespace calls with the DyanmoDB catalog.</li>
<li><a href="https://github.com/apache/iceberg/pull/3273">#3273</a> fixes importing Avro files via <code>add_files</code> by correctly setting the number of records.</li>
<li><a href="https://github.com/apache/iceberg/pull/3332">#3332</a> fixes importing ORC files with float or double columns in <code>add_files</code>.</li>
</ul>
<p>A more exhaustive list of changes is available under the <a href="https://github.com/apache/iceberg/milestone/15?closed=1">0.12.1 release milestone</a>.</p>
<h3 id="0120">0.12.0<a class="headerlink" href="#0120" title="Permanent link">🔗</a></h3>
<p>Apache Iceberg 0.12.0 was released on August 15, 2021. It consists of 395 commits authored by 74 contributors over a 139 day period.</p>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.12.0">0.12.0</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.12.0/apache-iceberg-0.12.0.tar.gz">0.12.0 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.12.0/apache-iceberg-0.12.0.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.12.0/apache-iceberg-0.12.0.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.12.0/iceberg-spark3-runtime-0.12.0.jar">0.12.0 Spark 3.x runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.12.0/iceberg-spark-runtime-0.12.0.jar">0.12.0 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime/0.12.0/iceberg-flink-runtime-0.12.0.jar">0.12.0 Flink runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.12.0/iceberg-hive-runtime-0.12.0.jar">0.12.0 Hive runtime Jar</a></li>
</ul>
<p><strong>High-level features:</strong></p>
<ul>
<li><strong>Core</strong><ul>
<li>Allow Iceberg schemas to specify one or more columns as row identifiers [<a href="https://github.com/apache/iceberg/pull/2465">#2465</a>]. Note that this is a prerequisite for supporting upserts in Flink.</li>
<li>Added JDBC [<a href="https://github.com/apache/iceberg/pull/1870">#1870</a>] and DynamoDB [<a href="https://github.com/apache/iceberg/pull/2688">#2688</a>] catalog implementations.</li>
<li>Added predicate pushdown for partitions and files metadata tables [<a href="https://github.com/apache/iceberg/pull/2358">#2358</a>, <a href="https://github.com/apache/iceberg/pull/2926">#2926</a>].</li>
<li>Added a new, more flexible compaction action for Spark that can support different strategies such as bin packing and sorting. [<a href="https://github.com/apache/iceberg/pull/2501">#2501</a>, <a href="https://github.com/apache/iceberg/pull/2609">#2609</a>].</li>
<li>Added the ability to upgrade to v2 or create a v2 table using the table property format-version=2 [<a href="https://github.com/apache/iceberg/pull/2887">#2887</a>].</li>
<li>Added support for nulls in StructLike collections [<a href="https://github.com/apache/iceberg/pull/2929">#2929</a>].</li>
<li>Added <code>key_metadata</code> field to manifest lists for encryption [<a href="https://github.com/apache/iceberg/pull/2675">#2675</a>].</li>
</ul>
</li>
<li><strong>Flink</strong><ul>
<li>Added support for SQL primary keys [<a href="https://github.com/apache/iceberg/pull/2410">#2410</a>].</li>
</ul>
</li>
<li><strong>Hive</strong><ul>
<li>Added the ability to set the catalog at the table level in the Hive Metastore. This makes it possible to write queries that reference tables from multiple catalogs [<a href="https://github.com/apache/iceberg/pull/2129">#2129</a>].</li>
<li>As a result of [<a href="https://github.com/apache/iceberg/pull/2129">#2129</a>], deprecated the configuration property <code>iceberg.mr.catalog</code> which was previously used to configure the Iceberg catalog in MapReduce and Hive [<a href="https://github.com/apache/iceberg/pull/2565">#2565</a>].</li>
<li>Added table-level JVM lock on commits[<a href="https://github.com/apache/iceberg/pull/2547">#2547</a>].</li>
<li>Added support for Hive's vectorized ORC reader [<a href="https://github.com/apache/iceberg/pull/2613">#2613</a>].</li>
</ul>
</li>
<li><strong>Spark</strong><ul>
<li>Added <code>SET</code> and <code>DROP IDENTIFIER FIELDS</code> clauses to <code>ALTER TABLE</code> so people don't have to look up the DDL [<a href="https://github.com/apache/iceberg/pull/2560">#2560</a>].</li>
<li>Added support for <code>ALTER TABLE REPLACE PARTITION FIELD</code> DDL [<a href="https://github.com/apache/iceberg/pull/2365">#2365</a>].</li>
<li>Added support for micro-batch streaming reads for structured streaming in Spark3 [<a href="https://github.com/apache/iceberg/pull/2660">#2660</a>].</li>
<li>Improved the performance of importing a Hive table by not loading all partitions from Hive and instead pushing the partition filter to the Metastore [<a href="https://github.com/apache/iceberg/pull/2777">#2777</a>].</li>
<li>Added support for <code>UPDATE</code> statements in Spark [<a href="https://github.com/apache/iceberg/pull/2193">#2193</a>, <a href="https://github.com/apache/iceberg/pull/2206">#2206</a>].</li>
<li>Added support for Spark 3.1 [<a href="https://github.com/apache/iceberg/pull/2512">#2512</a>].</li>
<li>Added <code>RemoveReachableFiles</code> action [<a href="https://github.com/apache/iceberg/pull/2415">#2415</a>].</li>
<li>Added <code>add_files</code> stored procedure [<a href="https://github.com/apache/iceberg/pull/2210">#2210</a>].</li>
<li>Refactored Actions API and added a new entry point.</li>
<li>Added support for Hadoop configuration overrides [<a href="https://github.com/apache/iceberg/pull/2922">#2922</a>].</li>
<li>Added support for the <code>TIMESTAMP WITHOUT TIMEZONE</code> type in Spark [<a href="https://github.com/apache/iceberg/pull/2757">#2757</a>].</li>
<li>Added validation that files referenced by row-level deletes are not concurrently rewritten [<a href="https://github.com/apache/iceberg/pull/2308">#2308</a>].</li>
</ul>
</li>
</ul>
<p><strong>Important bug fixes:</strong></p>
<ul>
<li><strong>Core</strong><ul>
<li>Fixed string bucketing with non-BMP characters [<a href="https://github.com/apache/iceberg/pull/2849">#2849</a>].</li>
<li>Fixed Parquet dictionary filtering with fixed-length byte arrays and decimals [<a href="https://github.com/apache/iceberg/pull/2551">#2551</a>].</li>
<li>Fixed a problem with the configuration of HiveCatalog [<a href="https://github.com/apache/iceberg/pull/2550">#2550</a>].</li>
<li>Fixed partition field IDs in table replacement [<a href="https://github.com/apache/iceberg/pull/2906">#2906</a>].</li>
</ul>
</li>
<li><strong>Hive</strong><ul>
<li>Enabled dropping HMS tables even if the metadata on disk gets corrupted [<a href="https://github.com/apache/iceberg/pull/2583">#2583</a>].</li>
</ul>
</li>
<li><strong>Parquet</strong><ul>
<li>Fixed Parquet row group filters when types are promoted from <code>int</code> to <code>long</code> or from <code>float</code> to <code>double</code> [<a href="https://github.com/apache/iceberg/pull/2232">#2232</a>]</li>
</ul>
</li>
<li><strong>Spark</strong><ul>
<li>Fixed <code>MERGE INTO</code> in Spark when used with <code>SinglePartition</code> partitioning [<a href="https://github.com/apache/iceberg/pull/2584">#2584</a>].</li>
<li>Fixed nested struct pruning in Spark [<a href="https://github.com/apache/iceberg/pull/2877">#2877</a>].</li>
<li>Fixed NaN handling for float and double metrics [<a href="https://github.com/apache/iceberg/pull/2464">#2464</a>].</li>
<li>Fixed Kryo serialization for data and delete files [<a href="https://github.com/apache/iceberg/pull/2343">#2343</a>].</li>
</ul>
</li>
</ul>
<p><strong>Other notable changes:</strong></p>
<ul>
<li>The Iceberg Community <a href="https://mail-archives.apache.org/mod_mbox/iceberg-dev/202107.mbox/%3cCAMwmD1-k1gnShK=wQ0PD88it6cg9mY7Y1hKHjDZ7L-jcDzpyZA@mail.gmail.com%3e">voted to approve</a> version 2 of the Apache Iceberg Format Specification. The differences between version 1 and 2 of the specification are documented <a href="../spec/#version-2">here</a>.</li>
<li>Bugfixes and stability improvements for NessieCatalog.</li>
<li>Improvements and fixes for Iceberg's Python library.</li>
<li>Added a vectorized reader for Apache Arrow [<a href="https://github.com/apache/iceberg/pull/2286">#2286</a>].</li>
<li>The following Iceberg dependencies were upgraded:<ul>
<li>Hive 2.3.8 [<a href="https://github.com/apache/iceberg/pull/2110">#2110</a>].</li>
<li>Avro 1.10.1 [<a href="https://github.com/apache/iceberg/pull/1648">#1648</a>].</li>
<li>Parquet 1.12.0 [<a href="https://github.com/apache/iceberg/pull/2441">#2441</a>].</li>
</ul>
</li>
</ul>
<h3 id="0111">0.11.1<a class="headerlink" href="#0111" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.11.1">0.11.1</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.11.1/apache-iceberg-0.11.1.tar.gz">0.11.1 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.11.1/apache-iceberg-0.11.1.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.11.1/apache-iceberg-0.11.1.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.11.1/iceberg-spark3-runtime-0.11.1.jar">0.11.1 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.11.1/iceberg-spark-runtime-0.11.1.jar">0.11.1 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime/0.11.1/iceberg-flink-runtime-0.11.1.jar">0.11.1 Flink runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.11.1/iceberg-hive-runtime-0.11.1.jar">0.11.1 Hive runtime Jar</a></li>
</ul>
<p>Important bug fixes:</p>
<ul>
<li><a href="https://github.com/apache/iceberg/pull/2367">#2367</a> prohibits deleting data files when tables are dropped if GC is disabled.</li>
<li><a href="https://github.com/apache/iceberg/pull/2196">#2196</a> fixes data loss after compaction when large files are split into multiple parts and only some parts are combined with other files.</li>
<li><a href="https://github.com/apache/iceberg/pull/2232">#2232</a> fixes row group filters with promoted types in Parquet.</li>
<li><a href="https://github.com/apache/iceberg/pull/2267">#2267</a> avoids listing non-Iceberg tables in Glue.</li>
<li><a href="https://github.com/apache/iceberg/pull/2254">#2254</a> fixes predicate pushdown for Date in Hive.</li>
<li><a href="https://github.com/apache/iceberg/pull/2126">#2126</a> fixes writing of Date, Decimal, Time, UUID types in Hive.</li>
<li><a href="https://github.com/apache/iceberg/pull/2241">#2241</a> fixes vectorized ORC reads with metadata columns in Spark.</li>
<li><a href="https://github.com/apache/iceberg/pull/2154">#2154</a> refreshes the relation cache in DELETE and MERGE operations in Spark.</li>
</ul>
<h3 id="0110">0.11.0<a class="headerlink" href="#0110" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.11.0">0.11.0</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.11.0/apache-iceberg-0.11.0.tar.gz">0.11.0 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.11.0/apache-iceberg-0.11.0.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.11.0/apache-iceberg-0.11.0.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.11.0/iceberg-spark3-runtime-0.11.0.jar">0.11.0 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.11.0/iceberg-spark-runtime-0.11.0.jar">0.11.0 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime/0.11.0/iceberg-flink-runtime-0.11.0.jar">0.11.0 Flink runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.11.0/iceberg-hive-runtime-0.11.0.jar">0.11.0 Hive runtime Jar</a></li>
</ul>
<p>High-level features:</p>
<ul>
<li><strong>Core API</strong> now supports partition spec and sort order evolution</li>
<li><strong>Spark 3</strong> now supports the following SQL extensions:<ul>
<li>MERGE INTO (experimental)</li>
<li>DELETE FROM (experimental)</li>
<li>ALTER TABLE ... ADD/DROP PARTITION</li>
<li>ALTER TABLE ... WRITE ORDERED BY</li>
<li>Invoke stored procedures using CALL</li>
</ul>
</li>
<li><strong>Flink</strong> now supports streaming reads, CDC writes (experimental), and filter pushdown</li>
<li><strong>AWS module</strong> is added to support better integration with AWS, with <a href="https://aws.amazon.com/glue/">AWS Glue catalog</a> support and dedicated S3 FileIO implementation</li>
<li><strong>Nessie module</strong> is added to support integration with <a href="https://projectnessie.org/">project Nessie</a></li>
</ul>
<p>Important bug fixes:</p>
<ul>
<li><a href="https://github.com/apache/iceberg/pull/1981">#1981</a> fixes bug that date and timestamp transforms were producing incorrect values for dates and times before 1970. Before the fix, negative values were incorrectly transformed by date and timestamp transforms to 1 larger than the correct value. For example, <code>day(1969-12-31 10:00:00)</code> produced 0 instead of -1. The fix is backwards compatible, which means predicate projection can still work with the incorrectly transformed partitions written using older versions.</li>
<li><a href="https://github.com/apache/iceberg/pull/2091">#2091</a> fixes <code>ClassCastException</code> for type promotion <code>int</code> to <code>long</code> and <code>float</code> to <code>double</code> during Parquet vectorized read. Now Arrow vector is created by looking at Parquet file schema instead of Iceberg schema for <code>int</code> and <code>float</code> fields.</li>
<li><a href="https://github.com/apache/iceberg/pull/1998">#1998</a> fixes bug in <code>HiveTableOperation</code> that <code>unlock</code> is not called if new metadata cannot be deleted. Now it is guaranteed that <code>unlock</code> is always called for Hive catalog users.</li>
<li><a href="https://github.com/apache/iceberg/pull/1979">#1979</a> fixes table listing failure in Hadoop catalog when user does not have permission to some tables. Now the tables with no permission are ignored in listing.</li>
<li><a href="https://github.com/apache/iceberg/pull/1798">#1798</a> fixes scan task failure when encountering duplicate entries of data files. Spark and Flink readers can now ignore duplicated entries in data files for each scan task.</li>
<li><a href="https://github.com/apache/iceberg/pull/1785">#1785</a> fixes invalidation of metadata tables in <code>CachingCatalog</code>. When a table is dropped, all the metadata tables associated with it are also invalidated in the cache.</li>
<li><a href="https://github.com/apache/iceberg/pull/1960">#1960</a> fixes bug that ORC writer does not read metrics config and always use the default. Now customized metrics config is respected.</li>
</ul>
<p>Other notable changes:</p>
<ul>
<li>NaN counts are now supported in metadata</li>
<li>Shared catalog properties are added in core library to standardize catalog level configurations</li>
<li>Spark and Flink now support dynamically loading customized <code>Catalog</code> and <code>FileIO</code> implementations</li>
<li>Spark 2 now supports loading tables from other catalogs, like Spark 3</li>
<li>Spark 3 now supports catalog names in DataFrameReader when using Iceberg as a format</li>
<li>Flink now uses the number of Iceberg read splits as its job parallelism to improve performance and save resource.</li>
<li>Hive (experimental) now supports INSERT INTO, case insensitive query, projection pushdown, create DDL with schema and auto type conversion</li>
<li>ORC now supports reading tinyint, smallint, char, varchar types</li>
<li>Avro to Iceberg schema conversion now preserves field docs</li>
</ul>
<h3 id="0100">0.10.0<a class="headerlink" href="#0100" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.10.0">0.10.0</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.10.0/apache-iceberg-0.10.0.tar.gz">0.10.0 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.10.0/apache-iceberg-0.10.0.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.10.0/apache-iceberg-0.10.0.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.10.0/iceberg-spark3-runtime-0.10.0.jar">0.10.0 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.10.0/iceberg-spark-runtime-0.10.0.jar">0.10.0 Spark 2.4 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-flink-runtime/0.10.0/iceberg-flink-runtime-0.10.0.jar">0.10.0 Flink runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-hive-runtime/0.10.0/iceberg-hive-runtime-0.10.0.jar">0.10.0 Hive runtime Jar</a></li>
</ul>
<p>High-level features:</p>
<ul>
<li><strong>Format v2 support</strong> for building row-level operations (<code>MERGE INTO</code>) in processing engines<ul>
<li>Note: format v2 is not yet finalized and does not have a forward-compatibility guarantee</li>
</ul>
</li>
<li><strong>Flink integration</strong> for writing to Iceberg tables and reading from Iceberg tables (reading supports batch mode only)</li>
<li><strong>Hive integration</strong> for reading from Iceberg tables, with filter pushdown (experimental; configuration may change)</li>
</ul>
<p>Important bug fixes:</p>
<ul>
<li><a href="https://github.com/apache/iceberg/pull/1706">#1706</a> fixes non-vectorized ORC reads in Spark that incorrectly skipped rows</li>
<li><a href="https://github.com/apache/iceberg/pull/1536">#1536</a> fixes ORC conversion of <code>notIn</code> and <code>notEqual</code> to match null values</li>
<li><a href="https://github.com/apache/iceberg/pull/1722">#1722</a> fixes <code>Expressions.notNull</code> returning an <code>isNull</code> predicate; API only, method was not used by processing engines</li>
<li><a href="https://github.com/apache/iceberg/pull/1736">#1736</a> fixes <code>IllegalArgumentException</code> in vectorized Spark reads with negative decimal values</li>
<li><a href="https://github.com/apache/iceberg/pull/1666">#1666</a> fixes file lengths returned by the ORC writer, using compressed size rather than uncompressed size</li>
<li><a href="https://github.com/apache/iceberg/pull/1674">#1674</a> removes catalog expiration in HiveCatalogs</li>
<li><a href="https://github.com/apache/iceberg/pull/1545">#1545</a> automatically refreshes tables in Spark when not caching table instances</li>
</ul>
<p>Other notable changes:</p>
<ul>
<li>The <code>iceberg-hive</code> module has been renamed to <code>iceberg-hive-metastore</code> to avoid confusion</li>
<li>Spark 3 is based on 3.0.1 that includes the fix for <a href="https://issues.apache.org/jira/browse/SPARK-32168">SPARK-32168</a></li>
<li>Hadoop tables will recover from version hint corruption</li>
<li>Tables can be configured with a required sort order</li>
<li>Data file locations can be customized with a dynamically loaded <code>LocationProvider</code></li>
<li>ORC file imports can apply a name mapping for stats</li>
</ul>
<p>A more exhaustive list of changes is available under the <a href="https://github.com/apache/iceberg/milestone/10?closed=1">0.10.0 release milestone</a>.</p>
<h3 id="091">0.9.1<a class="headerlink" href="#091" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.9.1">0.9.1</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.9.1/apache-iceberg-0.9.1.tar.gz">0.9.1 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.9.1/apache-iceberg-0.9.1.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.9.1/apache-iceberg-0.9.1.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.9.1/iceberg-spark3-runtime-0.9.1.jar">0.9.1 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.9.1/iceberg-spark-runtime-0.9.1.jar">0.9.1 Spark 2.4 runtime Jar</a></li>
</ul>
<h3 id="090">0.9.0<a class="headerlink" href="#090" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.9.0">0.9.0</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/iceberg/apache-iceberg-0.9.0/apache-iceberg-0.9.0.tar.gz">0.9.0 source tar.gz</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.9.0/apache-iceberg-0.9.0.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/iceberg/apache-iceberg-0.9.0/apache-iceberg-0.9.0.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark3-runtime/0.9.0/iceberg-spark3-runtime-0.9.0.jar">0.9.0 Spark 3.0 runtime Jar</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.9.0/iceberg-spark-runtime-0.9.0.jar">0.9.0 Spark 2.4 runtime Jar</a></li>
</ul>
<h3 id="080">0.8.0<a class="headerlink" href="#080" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.8.0-incubating">apache-iceberg-0.8.0-incubating</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/incubator/iceberg/apache-iceberg-0.8.0-incubating/apache-iceberg-0.8.0-incubating.tar.gz">0.8.0-incubating source tar.gz</a> -- <a href="https://downloads.apache.org/incubator/iceberg/apache-iceberg-0.8.0-incubating/apache-iceberg-0.8.0-incubating.tar.gz.asc">signature</a> -- <a href="https://downloads.apache.org/incubator/iceberg/apache-iceberg-0.8.0-incubating/apache-iceberg-0.8.0-incubating.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.8.0-incubating/iceberg-spark-runtime-0.8.0-incubating.jar">0.8.0-incubating Spark 2.4 runtime Jar</a></li>
</ul>
<h3 id="070">0.7.0<a class="headerlink" href="#070" title="Permanent link">🔗</a></h3>
<ul>
<li>Git tag: <a href="https://github.com/apache/iceberg/releases/tag/apache-iceberg-0.7.0-incubating">apache-iceberg-0.7.0-incubating</a></li>
<li><a href="https://www.apache.org/dyn/closer.cgi/incubator/iceberg/apache-iceberg-0.7.0-incubating/apache-iceberg-0.7.0-incubating.tar.gz">0.7.0-incubating source tar.gz</a> -- <a href="https://dist.apache.org/repos/dist/release/incubator/iceberg/apache-iceberg-0.7.0-incubating/apache-iceberg-0.7.0-incubating.tar.gz.asc">signature</a> -- <a href="https://dist.apache.org/repos/dist/release/incubator/iceberg/apache-iceberg-0.7.0-incubating/apache-iceberg-0.7.0-incubating.tar.gz.sha512">sha512</a></li>
<li><a href="https://search.maven.org/remotecontent?filepath=org/apache/iceberg/iceberg-spark-runtime/0.7.0-incubating/iceberg-spark-runtime-0.7.0-incubating.jar">0.7.0-incubating Spark 2.4 runtime Jar</a></li>
</ul>
</article>
</div>
<script>var tabs=__md_get("__tabs");if(Array.isArray(tabs))e:for(var set of document.querySelectorAll(".tabbed-set")){var tab,labels=set.querySelector(".tabbed-labels");for(tab of tabs)for(var label of labels.getElementsByTagName("label"))if(label.innerText.trim()===tab){var input=document.getElementById(label.htmlFor);input.checked=!0;continue e}}</script>
<script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
</div>
<button type="button" class="md-top md-icon" data-md-component="top" hidden>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M13 20h-2V8l-5.5 5.5-1.42-1.42L12 4.16l7.92 7.92-1.42 1.42L13 8v12Z"/></svg>
Back to top
</button>
</main>
<footer class="md-footer">
<div class="md-footer-meta md-typeset">
<div class="md-footer-meta__inner md-grid">
<div class="md-copyright">
<div class="md-copyright__highlight">
Apache Iceberg, Iceberg, Apache, the Apache feather logo, and the Apache Iceberg project logo are<br>either registered trademarks or trademarks of The Apache Software Foundation. Copyright © 2023<br>The Apache Software Foundation, Licensed under the <a href="https://www.apache.org/licenses/">Apache License, Version 2.0</a>.<br><br>
</div>
Made with
<a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
Material for MkDocs
</a>
</div>
</div>
</div>
</footer>
</div>
<div class="md-dialog" data-md-component="dialog">
<div class="md-dialog__inner md-typeset"></div>
</div>
<script id="__config" type="application/json">{"base": "..", "features": ["navigation.tabs", "navigation.tabs.sticky", "navigation.path", "navigation.top", "navigation.tracking", "toc.follow", "offline", "search.suggest", "search.highlight", "content.tabs.link", "content.code.copy", "content.code.annotate"], "search": "../assets/javascripts/workers/search.f886a092.min.js", "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}}</script>
<script src="../assets/javascripts/bundle.d7c377c4.min.js"></script>
<script src="../assets/javascript/extra.js"></script>
</body>
</html>