blob: fefd4d9f41f087954e73ca81f1ffc821d7eef2fc [file] [log] [blame]
<!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>FullNameTableProvider (Apache Beam 2.47.0)</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="FullNameTableProvider (Apache Beam 2.47.0)";
}
}
catch(err) {
}
//-->
var methods = {"i0":10,"i1":6,"i2":10};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],4:["t3","Abstract 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>Prev&nbsp;Class</li>
<li><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/InMemoryMetaTableProvider.html" title="class in org.apache.beam.sdk.extensions.sql.meta.provider"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../../../../index.html?org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html" target="_top">Frames</a></li>
<li><a href="FullNameTableProvider.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.beam.sdk.extensions.sql.meta.provider</div>
<h2 title="Class FullNameTableProvider" class="title">Class FullNameTableProvider</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li>java.lang.Object</li>
<li>
<ul class="inheritance">
<li>org.apache.beam.sdk.extensions.sql.meta.provider.FullNameTableProvider</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>All Implemented Interfaces:</dt>
<dd><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/CustomTableResolver.html" title="interface in org.apache.beam.sdk.extensions.sql.meta">CustomTableResolver</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a></dd>
</dl>
<dl>
<dt>Direct Known Subclasses:</dt>
<dd><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/datacatalog/DataCatalogTableProvider.html" title="class in org.apache.beam.sdk.extensions.sql.meta.provider.datacatalog">DataCatalogTableProvider</a></dd>
</dl>
<hr>
<br>
<pre><a href="../../../../../../../../org/apache/beam/sdk/annotations/Experimental.html" title="annotation in org.apache.beam.sdk.annotations">@Experimental</a>
public abstract class <span class="typeNameLabel">FullNameTableProvider</span>
extends java.lang.Object
implements <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/CustomTableResolver.html" title="interface in org.apache.beam.sdk.extensions.sql.meta">CustomTableResolver</a></pre>
<div class="block">Base class for table providers that look up table metadata using full table names, instead of
querying it by parts of the name separately.</div>
</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="colFirst" scope="col">Modifier</th>
<th class="colLast" scope="col">Constructor and Description</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>protected </code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html#FullNameTableProvider--">FullNameTableProvider</a></span>()</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="t3" class="tableTab"><span><a href="javascript:show(4);">Abstract 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/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html#getSubProvider-java.lang.String-">getSubProvider</a></span>(java.lang.String&nbsp;name)</code>
<div class="block">Returns a sub-provider, e.g.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>abstract <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/Table.html" title="class in org.apache.beam.sdk.extensions.sql.meta">Table</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html#getTableByFullName-org.apache.beam.sdk.extensions.sql.impl.TableName-">getTableByFullName</a></span>(<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/impl/TableName.html" title="class in org.apache.beam.sdk.extensions.sql.impl">TableName</a>&nbsp;fullTableName)</code>&nbsp;</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html#registerKnownTableNames-java.util.List-">registerKnownTableNames</a></span>(java.util.List&lt;<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/impl/TableName.html" title="class in org.apache.beam.sdk.extensions.sql.impl">TableName</a>&gt;&nbsp;tableNames)</code>
<div class="block">Register the table names as extracted from the FROM clause.</div>
</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, toString, wait, wait, wait</code></li>
</ul>
<ul class="blockList">
<li class="blockList"><a name="methods.inherited.from.class.org.apache.beam.sdk.extensions.sql.meta.provider.TableProvider">
<!-- -->
</a>
<h3>Methods inherited from interface&nbsp;org.apache.beam.sdk.extensions.sql.meta.provider.<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a></h3>
<code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#buildBeamSqlTable-org.apache.beam.sdk.extensions.sql.meta.Table-">buildBeamSqlTable</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#createTable-org.apache.beam.sdk.extensions.sql.meta.Table-">createTable</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#dropTable-java.lang.String-">dropTable</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getSubProviders--">getSubProviders</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getTable-java.lang.String-">getTable</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getTables--">getTables</a>, <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getTableType--">getTableType</a></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="FullNameTableProvider--">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>FullNameTableProvider</h4>
<pre>protected&nbsp;FullNameTableProvider()</pre>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!-- -->
</a>
<h3>Method Detail</h3>
<a name="getTableByFullName-org.apache.beam.sdk.extensions.sql.impl.TableName-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getTableByFullName</h4>
<pre>public abstract&nbsp;<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/Table.html" title="class in org.apache.beam.sdk.extensions.sql.meta">Table</a>&nbsp;getTableByFullName(<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/impl/TableName.html" title="class in org.apache.beam.sdk.extensions.sql.impl">TableName</a>&nbsp;fullTableName)</pre>
</li>
</ul>
<a name="registerKnownTableNames-java.util.List-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>registerKnownTableNames</h4>
<pre>public&nbsp;void&nbsp;registerKnownTableNames(java.util.List&lt;<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/impl/TableName.html" title="class in org.apache.beam.sdk.extensions.sql.impl">TableName</a>&gt;&nbsp;tableNames)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/CustomTableResolver.html#registerKnownTableNames-java.util.List-">CustomTableResolver</a></code></span></div>
<div class="block">Register the table names as extracted from the FROM clause.
<p>Calcite doesn't provide these full names to table providers and queries them with individual
parts of the identifiers without giving any extra context. So if a table provider needs to
implement some custom table name resolution strategy it doesn't have information to do so. E.g.
if you want to take the compound SQL identifiers that were originally split by dots, join them
into a single string, and then query a back-end service, this interface makes this possible.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/CustomTableResolver.html#registerKnownTableNames-java.util.List-">registerKnownTableNames</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/CustomTableResolver.html" title="interface in org.apache.beam.sdk.extensions.sql.meta">CustomTableResolver</a></code></dd>
</dl>
</li>
</ul>
<a name="getSubProvider-java.lang.String-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>getSubProvider</h4>
<pre>public&nbsp;<a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a>&nbsp;getSubProvider(java.lang.String&nbsp;name)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getSubProvider-java.lang.String-">TableProvider</a></code></span></div>
<div class="block">Returns a sub-provider, e.g. sub-schema. Temporary, this logic needs to live in <a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/impl/BeamCalciteSchema.html" title="class in org.apache.beam.sdk.extensions.sql.impl"><code>BeamCalciteSchema</code></a>.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html#getSubProvider-java.lang.String-">getSubProvider</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/TableProvider.html" title="interface in org.apache.beam.sdk.extensions.sql.meta.provider">TableProvider</a></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>Prev&nbsp;Class</li>
<li><a href="../../../../../../../../org/apache/beam/sdk/extensions/sql/meta/provider/InMemoryMetaTableProvider.html" title="class in org.apache.beam.sdk.extensions.sql.meta.provider"><span class="typeNameLink">Next&nbsp;Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../../../../index.html?org/apache/beam/sdk/extensions/sql/meta/provider/FullNameTableProvider.html" target="_top">Frames</a></li>
<li><a href="FullNameTableProvider.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>