<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html lang="en">
<head>
<!-- Generated by javadoc -->
<title>Schema</title>
<link rel="stylesheet" type="text/css" href="../../../stylesheet.css" title="Style">
<script type="text/javascript" src="../../../script.js"></script>
</head>
<body>
<script type="text/javascript"><!--
    try {
        if (location.href.indexOf('is-external=true') == -1) {
            parent.document.title="Schema";
        }
    }
    catch(err) {
    }
//-->
var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":10,"i8":10,"i9":10,"i10":10,"i11":10,"i12":10,"i13":10,"i14":10,"i15":10,"i16":10,"i17":10,"i18":10,"i19":10,"i20":10,"i21":10,"i22":10};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a name="navbar.top">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.top.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../index-all.html">Index</a></li>
<li><a href="../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../org/apache/iceberg/ScanTaskGroup.html" title="interface in org.apache.iceberg"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../org/apache/iceberg/SchemaParser.html" title="class in org.apache.iceberg"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../index.html?org/apache/iceberg/Schema.html" target="_top">Frames</a></li>
<li><a href="Schema.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_top");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.top">
<!--   -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
<!-- ======== START OF CLASS DATA ======== -->
<div class="header">
<div class="subTitle">org.apache.iceberg</div>
<h2 title="Class Schema" class="title">Class Schema</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li>java.lang.Object</li>
<li>
<ul class="inheritance">
<li>org.apache.iceberg.Schema</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>All Implemented Interfaces:</dt>
<dd>java.io.Serializable</dd>
</dl>
<hr>
<br>
<pre>public class <span class="typeNameLabel">Schema</span>
extends java.lang.Object
implements java.io.Serializable</pre>
<div class="block">The schema of a data table.

 <p>Schema ID will only be populated when reading from/writing to table metadata, otherwise it
 will be default to 0.</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../serialized-form.html#org.apache.iceberg.Schema">Serialized Form</a></dd>
</dl>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- ======== CONSTRUCTOR SUMMARY ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.summary">
<!--   -->
</a>
<h3>Constructor Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Constructor Summary table, listing constructors, and an explanation">
<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colOne" scope="col">Constructor and Description</th>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-int-java.util.List-">Schema</a></span>(int&nbsp;schemaId,
      java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns)</code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-int-java.util.List-java.util.Map-java.util.Set-">Schema</a></span>(int&nbsp;schemaId,
      java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
      java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases,
      java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-int-java.util.List-java.util.Set-">Schema</a></span>(int&nbsp;schemaId,
      java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
      java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-int-org.apache.iceberg.types.Types.NestedField...-">Schema</a></span>(int&nbsp;schemaId,
      <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>...&nbsp;columns)</code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-java.util.List-">Schema</a></span>(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns)</code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-java.util.List-java.util.Map-">Schema</a></span>(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
      java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases)</code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-java.util.List-java.util.Map-java.util.Set-">Schema</a></span>(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
      java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases,
      java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</code>&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-java.util.List-java.util.Set-">Schema</a></span>(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
      java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</code>&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#Schema-org.apache.iceberg.types.Types.NestedField...-">Schema</a></span>(<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>...&nbsp;columns)</code>&nbsp;</td>
</tr>
</table>
</li>
</ul>
<!-- ========== METHOD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="method.summary">
<!--   -->
</a>
<h3>Method Summary</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t4" class="tableTab"><span><a href="javascript:show(8);">Concrete Methods</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Method and Description</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/Accessor.html" title="interface in org.apache.iceberg">Accessor</a>&lt;<a href="../../../org/apache/iceberg/StructLike.html" title="interface in org.apache.iceberg">StructLike</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#accessorForField-int-">accessorForField</a></span>(int&nbsp;id)</code>
<div class="block">Returns an accessor for retrieving the data from <a href="../../../org/apache/iceberg/StructLike.html" title="interface in org.apache.iceberg"><code>StructLike</code></a>.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>java.lang.Integer</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#aliasToId-java.lang.String-">aliasToId</a></span>(java.lang.String&nbsp;alias)</code>
<div class="block">Returns the column id for the given column alias.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Types.StructType.html" title="class in org.apache.iceberg.types">Types.StructType</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#asStruct--">asStruct</a></span>()</code>
<div class="block">Returns the underlying <a href="../../../org/apache/iceberg/types/Types.StructType.html" title="class in org.apache.iceberg.types"><code>struct type</code></a> for this schema.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#caseInsensitiveFindField-java.lang.String-">caseInsensitiveFindField</a></span>(java.lang.String&nbsp;name)</code>
<div class="block">Returns a sub-field by name as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.</div>
</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#caseInsensitiveSelect-java.util.Collection-">caseInsensitiveSelect</a></span>(java.util.Collection&lt;java.lang.String&gt;&nbsp;names)</code>
<div class="block">Creates a projection schema for a subset of columns, selected by case insensitive names</div>
</td>
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#caseInsensitiveSelect-java.lang.String...-">caseInsensitiveSelect</a></span>(java.lang.String...&nbsp;names)</code>
<div class="block">Creates a projection schema for a subset of columns, selected by case insensitive names</div>
</td>
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code>java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#columns--">columns</a></span>()</code>
<div class="block">Returns a List of the <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>columns</code></a> in this Schema.</div>
</td>
</tr>
<tr id="i7" class="rowColor">
<td class="colFirst"><code>java.lang.String</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#findColumnName-int-">findColumnName</a></span>(int&nbsp;id)</code>
<div class="block">Returns the full column name for the given id.</div>
</td>
</tr>
<tr id="i8" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#findField-int-">findField</a></span>(int&nbsp;id)</code>
<div class="block">Returns the sub-field identified by the field id as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.</div>
</td>
</tr>
<tr id="i9" class="rowColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#findField-java.lang.String-">findField</a></span>(java.lang.String&nbsp;name)</code>
<div class="block">Returns a sub-field by name as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.</div>
</td>
</tr>
<tr id="i10" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types">Type</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#findType-int-">findType</a></span>(int&nbsp;id)</code>
<div class="block">Returns the <a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types"><code>Type</code></a> of a sub-field identified by the field id.</div>
</td>
</tr>
<tr id="i11" class="rowColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types">Type</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#findType-java.lang.String-">findType</a></span>(java.lang.String&nbsp;name)</code>
<div class="block">Returns the <a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types"><code>Type</code></a> of a sub-field identified by the field name.</div>
</td>
</tr>
<tr id="i12" class="altColor">
<td class="colFirst"><code>java.util.Map&lt;java.lang.String,java.lang.Integer&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#getAliases--">getAliases</a></span>()</code>
<div class="block">Returns an alias map for this schema, if set.</div>
</td>
</tr>
<tr id="i13" class="rowColor">
<td class="colFirst"><code>int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#highestFieldId--">highestFieldId</a></span>()</code>
<div class="block">Returns the highest field ID in this schema, including nested fields.</div>
</td>
</tr>
<tr id="i14" class="altColor">
<td class="colFirst"><code>java.util.Set&lt;java.lang.Integer&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#identifierFieldIds--">identifierFieldIds</a></span>()</code>
<div class="block">The set of identifier field IDs.</div>
</td>
</tr>
<tr id="i15" class="rowColor">
<td class="colFirst"><code>java.util.Set&lt;java.lang.String&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#identifierFieldNames--">identifierFieldNames</a></span>()</code>
<div class="block">Returns the set of identifier field names.</div>
</td>
</tr>
<tr id="i16" class="altColor">
<td class="colFirst"><code>java.lang.String</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#idToAlias-java.lang.Integer-">idToAlias</a></span>(java.lang.Integer&nbsp;fieldId)</code>
<div class="block">Returns the full column name in the unconverted data schema for the given column id.</div>
</td>
</tr>
<tr id="i17" class="rowColor">
<td class="colFirst"><code>java.util.Map&lt;java.lang.Integer,java.lang.String&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#idToName--">idToName</a></span>()</code>
<div class="block">Returns a map for this schema between field id and qualified field names.</div>
</td>
</tr>
<tr id="i18" class="altColor">
<td class="colFirst"><code>boolean</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#sameSchema-org.apache.iceberg.Schema-">sameSchema</a></span>(<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;anotherSchema)</code>
<div class="block">Checks whether this schema is equivalent to another schema while ignoring the schema ID.</div>
</td>
</tr>
<tr id="i19" class="rowColor">
<td class="colFirst"><code>int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#schemaId--">schemaId</a></span>()</code>
<div class="block">Returns the schema ID for this schema.</div>
</td>
</tr>
<tr id="i20" class="altColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#select-java.util.Collection-">select</a></span>(java.util.Collection&lt;java.lang.String&gt;&nbsp;names)</code>
<div class="block">Creates a projection schema for a subset of columns, selected by name.</div>
</td>
</tr>
<tr id="i21" class="rowColor">
<td class="colFirst"><code><a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#select-java.lang.String...-">select</a></span>(java.lang.String...&nbsp;names)</code>
<div class="block">Creates a projection schema for a subset of columns, selected by name.</div>
</td>
</tr>
<tr id="i22" class="altColor">
<td class="colFirst"><code>java.lang.String</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../org/apache/iceberg/Schema.html#toString--">toString</a></span>()</code>&nbsp;</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
<!--   -->
</a>
<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait</code></li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ========= CONSTRUCTOR DETAIL ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.detail">
<!--   -->
</a>
<h3>Constructor Detail</h3>
<a name="Schema-java.util.List-java.util.Map-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
              java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases)</pre>
</li>
</ul>
<a name="Schema-java.util.List-java.util.Map-java.util.Set-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
              java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases,
              java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</pre>
</li>
</ul>
<a name="Schema-java.util.List-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns)</pre>
</li>
</ul>
<a name="Schema-java.util.List-java.util.Set-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
              java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</pre>
</li>
</ul>
<a name="Schema-int-java.util.List-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(int&nbsp;schemaId,
              java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns)</pre>
</li>
</ul>
<a name="Schema-int-java.util.List-java.util.Set-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(int&nbsp;schemaId,
              java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
              java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</pre>
</li>
</ul>
<a name="Schema-int-java.util.List-java.util.Map-java.util.Set-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(int&nbsp;schemaId,
              java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns,
              java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;aliases,
              java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds)</pre>
</li>
</ul>
<a name="Schema-org.apache.iceberg.types.Types.NestedField...-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>...&nbsp;columns)</pre>
</li>
</ul>
<a name="Schema-int-org.apache.iceberg.types.Types.NestedField...-">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>Schema</h4>
<pre>public&nbsp;Schema(int&nbsp;schemaId,
              <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>...&nbsp;columns)</pre>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!--   -->
</a>
<h3>Method Detail</h3>
<a name="schemaId--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>schemaId</h4>
<pre>public&nbsp;int&nbsp;schemaId()</pre>
<div class="block">Returns the schema ID for this schema.

 <p>Note that schema ID will only be populated when reading from/writing to table metadata,
 otherwise it will be default to 0.</div>
</li>
</ul>
<a name="highestFieldId--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>highestFieldId</h4>
<pre>public&nbsp;int&nbsp;highestFieldId()</pre>
<div class="block">Returns the highest field ID in this schema, including nested fields.</div>
</li>
</ul>
<a name="getAliases--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getAliases</h4>
<pre>public&nbsp;java.util.Map&lt;java.lang.String,java.lang.Integer&gt;&nbsp;getAliases()</pre>
<div class="block">Returns an alias map for this schema, if set.

 <p>Alias maps are created when translating an external schema, like an Avro Schema, to this
 format. The original column names can be provided in a Map when constructing this Schema.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a Map of column aliases to field ids</dd>
</dl>
</li>
</ul>
<a name="idToName--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>idToName</h4>
<pre>public&nbsp;java.util.Map&lt;java.lang.Integer,java.lang.String&gt;&nbsp;idToName()</pre>
<div class="block">Returns a map for this schema between field id and qualified field names.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a map of field id to qualified field names</dd>
</dl>
</li>
</ul>
<a name="asStruct--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>asStruct</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Types.StructType.html" title="class in org.apache.iceberg.types">Types.StructType</a>&nbsp;asStruct()</pre>
<div class="block">Returns the underlying <a href="../../../org/apache/iceberg/types/Types.StructType.html" title="class in org.apache.iceberg.types"><code>struct type</code></a> for this schema.</div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the StructType version of this schema.</dd>
</dl>
</li>
</ul>
<a name="columns--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>columns</h4>
<pre>public&nbsp;java.util.List&lt;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&gt;&nbsp;columns()</pre>
<div class="block">Returns a List of the <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>columns</code></a> in this Schema.</div>
</li>
</ul>
<a name="identifierFieldIds--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>identifierFieldIds</h4>
<pre>public&nbsp;java.util.Set&lt;java.lang.Integer&gt;&nbsp;identifierFieldIds()</pre>
<div class="block">The set of identifier field IDs.

 <p>Identifier is a concept similar to primary key in a relational database system. It consists
 of a unique set of primitive fields in the schema. An identifier field must be at root, or
 nested in a chain of structs (no maps or lists). A row should be unique in a table based on the
 values of the identifier fields. Optional, float and double columns cannot be used as
 identifier fields. However, Iceberg identifier differs from primary key in the following ways:

 <ul>
   <li>Iceberg does not enforce the uniqueness of a row based on this identifier information. It
       is used for operations like upsert to define the default upsert key.
   <li>A nested field in a struct can be used as an identifier. For example, if there is a
       "last_name" field inside a "user" struct in a schema, field "user.last_name" can be set
       as a part of the identifier field.
 </ul>

 <p></div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the set of identifier field IDs in this schema.</dd>
</dl>
</li>
</ul>
<a name="identifierFieldNames--">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>identifierFieldNames</h4>
<pre>public&nbsp;java.util.Set&lt;java.lang.String&gt;&nbsp;identifierFieldNames()</pre>
<div class="block">Returns the set of identifier field names.</div>
</li>
</ul>
<a name="findType-java.lang.String-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findType</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types">Type</a>&nbsp;findType(java.lang.String&nbsp;name)</pre>
<div class="block">Returns the <a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types"><code>Type</code></a> of a sub-field identified by the field name.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - a field name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a Type for the sub-field or null if it is not found</dd>
</dl>
</li>
</ul>
<a name="findType-int-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findType</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types">Type</a>&nbsp;findType(int&nbsp;id)</pre>
<div class="block">Returns the <a href="../../../org/apache/iceberg/types/Type.html" title="interface in org.apache.iceberg.types"><code>Type</code></a> of a sub-field identified by the field id.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>id</code> - a field id</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a Type for the sub-field or null if it is not found</dd>
</dl>
</li>
</ul>
<a name="findField-int-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findField</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&nbsp;findField(int&nbsp;id)</pre>
<div class="block">Returns the sub-field identified by the field id as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>id</code> - a field id</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the sub-field or null if it is not found</dd>
</dl>
</li>
</ul>
<a name="findField-java.lang.String-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findField</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&nbsp;findField(java.lang.String&nbsp;name)</pre>
<div class="block">Returns a sub-field by name as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.

 <p>The result may be a top-level or a nested field.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - a String name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a Type for the sub-field or null if it is not found</dd>
</dl>
</li>
</ul>
<a name="caseInsensitiveFindField-java.lang.String-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>caseInsensitiveFindField</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types">Types.NestedField</a>&nbsp;caseInsensitiveFindField(java.lang.String&nbsp;name)</pre>
<div class="block">Returns a sub-field by name as a <a href="../../../org/apache/iceberg/types/Types.NestedField.html" title="class in org.apache.iceberg.types"><code>Types.NestedField</code></a>.

 <p>The result may be a top-level or a nested field.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - a String name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the sub-field or null if it is not found</dd>
</dl>
</li>
</ul>
<a name="findColumnName-int-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>findColumnName</h4>
<pre>public&nbsp;java.lang.String&nbsp;findColumnName(int&nbsp;id)</pre>
<div class="block">Returns the full column name for the given id.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>id</code> - a field id</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the full column name in this schema that resolves to the id</dd>
</dl>
</li>
</ul>
<a name="aliasToId-java.lang.String-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>aliasToId</h4>
<pre>public&nbsp;java.lang.Integer&nbsp;aliasToId(java.lang.String&nbsp;alias)</pre>
<div class="block">Returns the column id for the given column alias. Column aliases are set by conversions from
 Parquet or Avro to this Schema type.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>alias</code> - a full column name in the unconverted data schema</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the column id in this schema, or null if the column wasn't found</dd>
</dl>
</li>
</ul>
<a name="idToAlias-java.lang.Integer-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>idToAlias</h4>
<pre>public&nbsp;java.lang.String&nbsp;idToAlias(java.lang.Integer&nbsp;fieldId)</pre>
<div class="block">Returns the full column name in the unconverted data schema for the given column id. Column
 aliases are set by conversions from Parquet or Avro to this Schema type.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>fieldId</code> - a column id in this schema</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the full column name in the unconverted data schema, or null if one wasn't found</dd>
</dl>
</li>
</ul>
<a name="accessorForField-int-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>accessorForField</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/Accessor.html" title="interface in org.apache.iceberg">Accessor</a>&lt;<a href="../../../org/apache/iceberg/StructLike.html" title="interface in org.apache.iceberg">StructLike</a>&gt;&nbsp;accessorForField(int&nbsp;id)</pre>
<div class="block">Returns an accessor for retrieving the data from <a href="../../../org/apache/iceberg/StructLike.html" title="interface in org.apache.iceberg"><code>StructLike</code></a>.

 <p>Accessors do not retrieve data contained in lists or maps.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>id</code> - a column id in this schema</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>an <a href="../../../org/apache/iceberg/Accessor.html" title="interface in org.apache.iceberg"><code>Accessor</code></a> to retrieve values from a <a href="../../../org/apache/iceberg/StructLike.html" title="interface in org.apache.iceberg"><code>StructLike</code></a> row</dd>
</dl>
</li>
</ul>
<a name="select-java.lang.String...-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>select</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;select(java.lang.String...&nbsp;names)</pre>
<div class="block">Creates a projection schema for a subset of columns, selected by name.

 <p>Names that identify nested fields will select part or all of the field's top-level column.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>names</code> - String names for selected columns</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a projection schema from this schema, by name</dd>
</dl>
</li>
</ul>
<a name="select-java.util.Collection-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>select</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;select(java.util.Collection&lt;java.lang.String&gt;&nbsp;names)</pre>
<div class="block">Creates a projection schema for a subset of columns, selected by name.

 <p>Names that identify nested fields will select part or all of the field's top-level column.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>names</code> - a List of String names for selected columns</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a projection schema from this schema, by name</dd>
</dl>
</li>
</ul>
<a name="caseInsensitiveSelect-java.lang.String...-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>caseInsensitiveSelect</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;caseInsensitiveSelect(java.lang.String...&nbsp;names)</pre>
<div class="block">Creates a projection schema for a subset of columns, selected by case insensitive names

 <p>Names that identify nested fields will select part or all of the field's top-level column.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>names</code> - a List of String names for selected columns</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a projection schema from this schema, by names</dd>
</dl>
</li>
</ul>
<a name="caseInsensitiveSelect-java.util.Collection-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>caseInsensitiveSelect</h4>
<pre>public&nbsp;<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;caseInsensitiveSelect(java.util.Collection&lt;java.lang.String&gt;&nbsp;names)</pre>
<div class="block">Creates a projection schema for a subset of columns, selected by case insensitive names

 <p>Names that identify nested fields will select part or all of the field's top-level column.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>names</code> - a List of String names for selected columns</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>a projection schema from this schema, by names</dd>
</dl>
</li>
</ul>
<a name="sameSchema-org.apache.iceberg.Schema-">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>sameSchema</h4>
<pre>public&nbsp;boolean&nbsp;sameSchema(<a href="../../../org/apache/iceberg/Schema.html" title="class in org.apache.iceberg">Schema</a>&nbsp;anotherSchema)</pre>
<div class="block">Checks whether this schema is equivalent to another schema while ignoring the schema ID.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>anotherSchema</code> - another schema</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if this schema is equivalent to the given schema</dd>
</dl>
</li>
</ul>
<a name="toString--">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>toString</h4>
<pre>public&nbsp;java.lang.String&nbsp;toString()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
<dd><code>toString</code>&nbsp;in class&nbsp;<code>java.lang.Object</code></dd>
</dl>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
</div>
<!-- ========= END OF CLASS DATA ========= -->
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a name="navbar.bottom">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a name="navbar.bottom.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../overview-summary.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../index-all.html">Index</a></li>
<li><a href="../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../org/apache/iceberg/ScanTaskGroup.html" title="interface in org.apache.iceberg"><span class="typeNameLink">Prev&nbsp;Class</span></a></li>
<li><a href="../../../org/apache/iceberg/SchemaParser.html" title="class in org.apache.iceberg"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../index.html?org/apache/iceberg/Schema.html" target="_top">Frames</a></li>
<li><a href="Schema.html" target="_top">No&nbsp;Frames</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../allclasses-noframe.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_bottom");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">Constr</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a name="skip.navbar.bottom">
<!--   -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</body>
</html>
