blob: ded5f08c8c8813f72d3c859abf6467383b15e136 [file] [log] [blame]
<!DOCTYPE HTML>
<!-- NewPage -->
<html lang="en">
<head>
<!-- Generated by javadoc -->
<title>Uses of Interface org.apache.calcite.rel.metadata.MetadataHandler (Apache Calcite API)</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
<link rel="stylesheet" type="text/css" href="../../../../../../jquery/jquery-ui.css" title="Style">
<script type="text/javascript" src="../../../../../../script.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jszip/dist/jszip.min.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jszip-utils/dist/jszip-utils.min.js"></script>
<!--[if IE]>
<script type="text/javascript" src="../../../../../../jquery/jszip-utils/dist/jszip-utils-ie.min.js"></script>
<![endif]-->
<script type="text/javascript" src="../../../../../../jquery/jquery-3.3.1.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jquery-migrate-3.0.1.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jquery-ui.js"></script>
</head>
<body>
<script type="text/javascript"><!--
try {
if (location.href.indexOf('is-external=true') == -1) {
parent.document.title="Uses of Interface org.apache.calcite.rel.metadata.MetadataHandler (Apache Calcite API)";
}
}
catch(err) {
}
//-->
var pathtoroot = "../../../../../../";
var useModuleDirectories = true;
loadScripts(document, 'script');</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<header role="banner">
<nav role="navigation">
<div class="fixedNav">
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a id="navbar.top">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.top.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../../index.html">Overview</a></li>
<li><a href="../package-summary.html">Package</a></li>
<li><a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">Class</a></li>
<li class="navBarCell1Rev">Use</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" id="allclasses_navbar_top">
<li><a href="../../../../../../allclasses.html">All&nbsp;Classes</a></li>
</ul>
<ul class="navListSearch">
<li><label for="search">SEARCH:</label>
<input type="text" id="search" value="search" disabled="disabled">
<input type="reset" id="reset" value="reset" disabled="disabled">
</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>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</div>
<a id="skip.navbar.top">
<!-- -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
</div>
<div class="navPadding">&nbsp;</div>
<script type="text/javascript"><!--
$('.navPadding').css('padding-top', $('.fixedNav').css("height"));
//-->
</script>
</nav>
</header>
<main role="main">
<div class="header">
<h2 title="Uses of Interface org.apache.calcite.rel.metadata.MetadataHandler" class="title">Uses of Interface<br>org.apache.calcite.rel.metadata.MetadataHandler</h2>
</div>
<div class="classUseContainer">
<ul class="blockList">
<li class="blockList">
<table class="useSummary">
<caption><span>Packages that use <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Package</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<th class="colFirst" scope="row"><a href="#org.apache.calcite.plan.hep">org.apache.calcite.plan.hep</a></th>
<td class="colLast">
<div class="block">Provides a heuristic planner implementation for the interfaces in
<a href="../../../plan/package-summary.html"><code>org.apache.calcite.plan</code></a>.</div>
</td>
</tr>
<tr class="rowColor">
<th class="colFirst" scope="row"><a href="#org.apache.calcite.plan.volcano">org.apache.calcite.plan.volcano</a></th>
<td class="colLast">
<div class="block">Optimizes relational expressions.</div>
</td>
</tr>
<tr class="altColor">
<th class="colFirst" scope="row"><a href="#org.apache.calcite.rel.metadata">org.apache.calcite.rel.metadata</a></th>
<td class="colLast">
<div class="block">Defines metadata interfaces and utilities for relational
expressions.</div>
</td>
</tr>
</tbody>
</table>
</li>
<li class="blockList">
<ul class="blockList">
<li class="blockList">
<section role="region"><a id="org.apache.calcite.plan.hep">
<!-- -->
</a>
<h3>Uses of <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a> in <a href="../../../plan/hep/package-summary.html">org.apache.calcite.plan.hep</a></h3>
<table class="useSummary">
<caption><span>Methods in <a href="../../../plan/hep/package-summary.html">org.apache.calcite.plan.hep</a> that return types with arguments of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">HepRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../../../plan/hep/HepRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
</section>
</li>
<li class="blockList">
<section role="region"><a id="org.apache.calcite.plan.volcano">
<!-- -->
</a>
<h3>Uses of <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a> in <a href="../../../plan/volcano/package-summary.html">org.apache.calcite.plan.volcano</a></h3>
<table class="useSummary">
<caption><span>Methods in <a href="../../../plan/volcano/package-summary.html">org.apache.calcite.plan.volcano</a> that return types with arguments of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">VolcanoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../../../plan/volcano/VolcanoRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
</section>
</li>
<li class="blockList">
<section role="region"><a id="org.apache.calcite.rel.metadata">
<!-- -->
</a>
<h3>Uses of <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a> in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a></h3>
<table class="useSummary">
<caption><span>Subinterfaces of <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a> in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Interface</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.AllPredicates.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.AllPredicates.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Collation.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Collation.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.ColumnOrigin.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.ColumnOrigin.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.ColumnUniqueness.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.ColumnUniqueness.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.CumulativeCost.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.CumulativeCost.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.DistinctRowCount.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.DistinctRowCount.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Distribution.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Distribution.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.ExplainVisibility.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.ExplainVisibility.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.ExpressionLineage.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.ExpressionLineage.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.MaxRowCount.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.MaxRowCount.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Memory.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Memory.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.MinRowCount.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.MinRowCount.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.NodeTypes.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.NodeTypes.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.NonCumulativeCost.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.NonCumulativeCost.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Parallelism.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Parallelism.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.PercentageOriginalRows.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.PercentageOriginalRows.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.PopulationSize.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.PopulationSize.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Predicates.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Predicates.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.RowCount.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.RowCount.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Selectivity.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Selectivity.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.Size.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.Size.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.TableReferences.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.TableReferences.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static interface&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../BuiltInMetadata.UniqueKeys.Handler.html" title="interface in org.apache.calcite.rel.metadata">BuiltInMetadata.UniqueKeys.Handler</a></span></code></th>
<td class="colLast">
<div class="block">Handler API.</div>
</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Classes in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> that implement <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Class</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdAllPredicates.html" title="class in org.apache.calcite.rel.metadata">RelMdAllPredicates</a></span></code></th>
<td class="colLast">
<div class="block">Utility to extract Predicates that are present in the (sub)plan
starting at this node.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdCollation.html" title="class in org.apache.calcite.rel.metadata">RelMdCollation</a></span></code></th>
<td class="colLast">
<div class="block">RelMdCollation supplies a default implementation of
<a href="../RelMetadataQuery.html#collations(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.collations(org.apache.calcite.rel.RelNode)</code></a>
for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdColumnOrigins.html" title="class in org.apache.calcite.rel.metadata">RelMdColumnOrigins</a></span></code></th>
<td class="colLast">
<div class="block">RelMdColumnOrigins supplies a default implementation of
<a href="../RelMetadataQuery.html#getColumnOrigins(org.apache.calcite.rel.RelNode,int)"><code>RelMetadataQuery.getColumnOrigins(org.apache.calcite.rel.RelNode, int)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdColumnUniqueness.html" title="class in org.apache.calcite.rel.metadata">RelMdColumnUniqueness</a></span></code></th>
<td class="colLast">
<div class="block">RelMdColumnUniqueness supplies a default implementation of
<a href="../RelMetadataQuery.html#areColumnsUnique(org.apache.calcite.rel.RelNode,org.apache.calcite.util.ImmutableBitSet)"><code>RelMetadataQuery.areColumnsUnique(org.apache.calcite.rel.RelNode, org.apache.calcite.util.ImmutableBitSet)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdDistinctRowCount.html" title="class in org.apache.calcite.rel.metadata">RelMdDistinctRowCount</a></span></code></th>
<td class="colLast">
<div class="block">RelMdDistinctRowCount supplies a default implementation of
<a href="../RelMetadataQuery.html#getDistinctRowCount(org.apache.calcite.rel.RelNode,org.apache.calcite.util.ImmutableBitSet,org.apache.calcite.rex.RexNode)"><code>RelMetadataQuery.getDistinctRowCount(org.apache.calcite.rel.RelNode, org.apache.calcite.util.ImmutableBitSet, org.apache.calcite.rex.RexNode)</code></a> for the standard logical
algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdDistribution.html" title="class in org.apache.calcite.rel.metadata">RelMdDistribution</a></span></code></th>
<td class="colLast">
<div class="block">RelMdCollation supplies a default implementation of
<a href="../RelMetadataQuery.html#distribution(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.distribution(org.apache.calcite.rel.RelNode)</code></a>
for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdExplainVisibility.html" title="class in org.apache.calcite.rel.metadata">RelMdExplainVisibility</a></span></code></th>
<td class="colLast">
<div class="block">RelMdExplainVisibility supplies a default implementation of
<a href="../RelMetadataQuery.html#isVisibleInExplain(org.apache.calcite.rel.RelNode,org.apache.calcite.sql.SqlExplainLevel)"><code>RelMetadataQuery.isVisibleInExplain(org.apache.calcite.rel.RelNode, org.apache.calcite.sql.SqlExplainLevel)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdExpressionLineage.html" title="class in org.apache.calcite.rel.metadata">RelMdExpressionLineage</a></span></code></th>
<td class="colLast">
<div class="block">Default implementation of
<a href="../RelMetadataQuery.html#getExpressionLineage(org.apache.calcite.rel.RelNode,org.apache.calcite.rex.RexNode)"><code>RelMetadataQuery.getExpressionLineage(org.apache.calcite.rel.RelNode, org.apache.calcite.rex.RexNode)</code></a> for the standard logical
algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdMaxRowCount.html" title="class in org.apache.calcite.rel.metadata">RelMdMaxRowCount</a></span></code></th>
<td class="colLast">
<div class="block">RelMdMaxRowCount supplies a default implementation of
<a href="../RelMetadataQuery.html#getMaxRowCount(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getMaxRowCount(org.apache.calcite.rel.RelNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdMemory.html" title="class in org.apache.calcite.rel.metadata">RelMdMemory</a></span></code></th>
<td class="colLast">
<div class="block">Default implementations of the
<a href="../BuiltInMetadata.Memory.html" title="interface in org.apache.calcite.rel.metadata"><code>BuiltInMetadata.Memory</code></a>
metadata provider for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdMinRowCount.html" title="class in org.apache.calcite.rel.metadata">RelMdMinRowCount</a></span></code></th>
<td class="colLast">
<div class="block">RelMdMinRowCount supplies a default implementation of
<a href="../RelMetadataQuery.html#getMinRowCount(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getMinRowCount(org.apache.calcite.rel.RelNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdNodeTypes.html" title="class in org.apache.calcite.rel.metadata">RelMdNodeTypes</a></span></code></th>
<td class="colLast">
<div class="block">RelMdNodeTypeCount supplies a default implementation of
<a href="../RelMetadataQuery.html#getNodeTypes(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getNodeTypes(org.apache.calcite.rel.RelNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdParallelism.html" title="class in org.apache.calcite.rel.metadata">RelMdParallelism</a></span></code></th>
<td class="colLast">
<div class="block">Default implementations of the
<a href="../BuiltInMetadata.Parallelism.html" title="interface in org.apache.calcite.rel.metadata"><code>BuiltInMetadata.Parallelism</code></a>
metadata provider for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdPercentageOriginalRows.html" title="class in org.apache.calcite.rel.metadata">RelMdPercentageOriginalRows</a></span></code></th>
<td class="colLast">
<div class="block">RelMdPercentageOriginalRows supplies a default implementation of
<a href="../RelMetadataQuery.html#getPercentageOriginalRows(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getPercentageOriginalRows(org.apache.calcite.rel.RelNode)</code></a> for the standard logical
algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdPopulationSize.html" title="class in org.apache.calcite.rel.metadata">RelMdPopulationSize</a></span></code></th>
<td class="colLast">
<div class="block">RelMdPopulationSize supplies a default implementation of
<a href="../RelMetadataQuery.html#getPopulationSize(org.apache.calcite.rel.RelNode,org.apache.calcite.util.ImmutableBitSet)"><code>RelMetadataQuery.getPopulationSize(org.apache.calcite.rel.RelNode, org.apache.calcite.util.ImmutableBitSet)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdPredicates.html" title="class in org.apache.calcite.rel.metadata">RelMdPredicates</a></span></code></th>
<td class="colLast">
<div class="block">Utility to infer Predicates that are applicable above a RelNode.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdRowCount.html" title="class in org.apache.calcite.rel.metadata">RelMdRowCount</a></span></code></th>
<td class="colLast">
<div class="block">RelMdRowCount supplies a default implementation of
<a href="../RelMetadataQuery.html#getRowCount(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getRowCount(org.apache.calcite.rel.RelNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdSelectivity.html" title="class in org.apache.calcite.rel.metadata">RelMdSelectivity</a></span></code></th>
<td class="colLast">
<div class="block">RelMdSelectivity supplies a default implementation of
<a href="../RelMetadataQuery.html#getSelectivity(org.apache.calcite.rel.RelNode,org.apache.calcite.rex.RexNode)"><code>RelMetadataQuery.getSelectivity(org.apache.calcite.rel.RelNode, org.apache.calcite.rex.RexNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdSize.html" title="class in org.apache.calcite.rel.metadata">RelMdSize</a></span></code></th>
<td class="colLast">
<div class="block">Default implementations of the
<a href="../BuiltInMetadata.Size.html" title="interface in org.apache.calcite.rel.metadata"><code>BuiltInMetadata.Size</code></a>
metadata provider for the standard logical algebra.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdTableReferences.html" title="class in org.apache.calcite.rel.metadata">RelMdTableReferences</a></span></code></th>
<td class="colLast">
<div class="block">Default implementation of <a href="../RelMetadataQuery.html#getTableReferences(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getTableReferences(org.apache.calcite.rel.RelNode)</code></a> for the
standard logical algebra.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>class&nbsp;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../RelMdUniqueKeys.html" title="class in org.apache.calcite.rel.metadata">RelMdUniqueKeys</a></span></code></th>
<td class="colLast">
<div class="block">RelMdUniqueKeys supplies a default implementation of
<a href="../RelMetadataQuery.html#getUniqueKeys(org.apache.calcite.rel.RelNode)"><code>RelMetadataQuery.getUniqueKeys(org.apache.calcite.rel.RelNode)</code></a> for the standard logical algebra.</div>
</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Fields in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> with type parameters of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Field</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>java.lang.Class&lt;? extends <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;<a href="../MetadataDef.html" title="type parameter in MetadataDef">M</a>&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">MetadataDef.</span><code><span class="memberNameLink"><a href="../MetadataDef.html#handlerClass">handlerClass</a></span></code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private com.google.common.collect.ImmutableMultimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#handlerMap">handlerMap</a></span></code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private static com.google.common.cache.LoadingCache&lt;<a href="../JaninoRelMetadataProvider.Key.html" title="class in org.apache.calcite.rel.metadata">JaninoRelMetadataProvider.Key</a>,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#HANDLERS">HANDLERS</a></span></code></th>
<td class="colLast">
<div class="block">Cache of pre-generated handlers by provider and kind of metadata.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>(package private) com.google.common.collect.ImmutableMultimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.Space.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.Space.html#providerMap">providerMap</a></span></code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Methods in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> with type parameters of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>(package private) &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>,&#8203;H extends <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;<br>H</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#create(org.apache.calcite.rel.metadata.MetadataDef)">create</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>(package private) &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>,&#8203;H extends <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;<br>H</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#revise(java.lang.Class,org.apache.calcite.rel.metadata.MetadataDef)">revise</a></span>&#8203;(java.lang.Class&lt;? extends <a href="../../RelNode.html" title="interface in org.apache.calcite.rel">RelNode</a>&gt;&nbsp;rClass,
<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>protected &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>,&#8203;H extends <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;<br>H</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">RelMetadataQuery.</span><code><span class="memberNameLink"><a href="../RelMetadataQuery.html#revise(java.lang.Class,org.apache.calcite.rel.metadata.MetadataDef)">revise</a></span>&#8203;(java.lang.Class&lt;? extends <a href="../../RelNode.html" title="interface in org.apache.calcite.rel">RelNode</a>&gt;&nbsp;class_,
<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">
<div class="block">Re-generates the handler for a given kind of metadata, adding support for
<code>class_</code> if it is not already present.</div>
</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Methods in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> that return <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>(package private) static &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br><a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#compile(java.lang.String,java.lang.String,org.apache.calcite.rel.metadata.MetadataDef,java.util.List)">compile</a></span>&#8203;(java.lang.String&nbsp;className,
java.lang.String&nbsp;classBody,
<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def,
java.util.List&lt;java.lang.Object&gt;&nbsp;argList)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private static &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br><a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#load3(org.apache.calcite.rel.metadata.MetadataDef,com.google.common.collect.Multimap,com.google.common.collect.ImmutableList)">load3</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def,
com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;&nbsp;map,
com.google.common.collect.ImmutableList&lt;java.lang.Class&lt;? extends <a href="../../RelNode.html" title="interface in org.apache.calcite.rel">RelNode</a>&gt;&gt;&nbsp;relClasses)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Methods in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> that return types with arguments of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">CachingRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../CachingRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ChainedRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ChainedRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>&lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br>com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">RelMetadataProvider.</span><code><span class="memberNameLink"><a href="../RelMetadataProvider.html#handlers(org.apache.calcite.rel.metadata.MetadataDef)">handlers</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Methods in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> with parameters of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../ReflectiveRelMetadataProvider.Space2.html" title="class in org.apache.calcite.rel.metadata">ReflectiveRelMetadataProvider.Space2</a></code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.Space2.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.Space2.html#create(org.apache.calcite.rel.metadata.MetadataHandler,com.google.common.collect.ImmutableList)">create</a></span>&#8203;(<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&nbsp;target,
com.google.common.collect.ImmutableList&lt;java.lang.reflect.Method&gt;&nbsp;methods)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../RelMetadataProvider.html" title="interface in org.apache.calcite.rel.metadata">RelMetadataProvider</a></code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#reflectiveSource(java.lang.reflect.Method,org.apache.calcite.rel.metadata.MetadataHandler)">reflectiveSource</a></span>&#8203;(java.lang.reflect.Method&nbsp;method,
<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&nbsp;target)</code></th>
<td class="colLast">
<div class="block">Returns an implementation of <a href="../RelMetadataProvider.html" title="interface in org.apache.calcite.rel.metadata"><code>RelMetadataProvider</code></a> that scans for
methods with a preceding argument.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private static <a href="../RelMetadataProvider.html" title="interface in org.apache.calcite.rel.metadata">RelMetadataProvider</a></code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#reflectiveSource(org.apache.calcite.rel.metadata.MetadataHandler,com.google.common.collect.ImmutableList)">reflectiveSource</a></span>&#8203;(<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&nbsp;target,
com.google.common.collect.ImmutableList&lt;java.lang.reflect.Method&gt;&nbsp;methods)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../RelMetadataProvider.html" title="interface in org.apache.calcite.rel.metadata">RelMetadataProvider</a></code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">ReflectiveRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#reflectiveSource(org.apache.calcite.rel.metadata.MetadataHandler,java.lang.reflect.Method...)">reflectiveSource</a></span>&#8203;(<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&nbsp;target,
java.lang.reflect.Method...&nbsp;methods)</code></th>
<td class="colLast">
<div class="block">Returns a reflective metadata provider that implements several
methods.</div>
</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Method parameters in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> with type arguments of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<td class="colFirst"><code>private static java.lang.String</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#findProvider(java.util.List,java.lang.Class)">findProvider</a></span>&#8203;(java.util.List&lt;<a href="../../../util/Pair.html" title="class in org.apache.calcite.util">Pair</a>&lt;java.lang.String,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;&gt;&nbsp;providerList,
java.lang.Class&lt;?&gt;&nbsp;declaringClass)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private static &lt;M extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;<br><a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;</code></td>
<th class="colSecond" scope="row"><span class="typeNameLabel">JaninoRelMetadataProvider.</span><code><span class="memberNameLink"><a href="../JaninoRelMetadataProvider.html#load3(org.apache.calcite.rel.metadata.MetadataDef,com.google.common.collect.Multimap,com.google.common.collect.ImmutableList)">load3</a></span>&#8203;(<a href="../MetadataDef.html" title="class in org.apache.calcite.rel.metadata">MetadataDef</a>&lt;M&gt;&nbsp;def,
com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&lt;M&gt;&gt;&nbsp;map,
com.google.common.collect.ImmutableList&lt;java.lang.Class&lt;? extends <a href="../../RelNode.html" title="interface in org.apache.calcite.rel">RelNode</a>&gt;&gt;&nbsp;relClasses)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
<table class="useSummary">
<caption><span>Constructor parameters in <a href="../package-summary.html">org.apache.calcite.rel.metadata</a> with type arguments of type <a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a></span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Constructor</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tbody>
<tr class="altColor">
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.html#%3Cinit%3E(java.util.concurrent.ConcurrentMap,java.lang.Class,com.google.common.collect.Multimap)">ReflectiveRelMetadataProvider</a></span>&#8203;(java.util.concurrent.ConcurrentMap&lt;java.lang.Class&lt;<a href="../../RelNode.html" title="interface in org.apache.calcite.rel">RelNode</a>&gt;,&#8203;<a href="../UnboundMetadata.html" title="interface in org.apache.calcite.rel.metadata">UnboundMetadata</a>&gt;&nbsp;map,
java.lang.Class&lt;? extends <a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;&nbsp;metadataClass0,
com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;&nbsp;handlerMap)</code></th>
<td class="colLast">
<div class="block">Creates a ReflectiveRelMetadataProvider.</div>
</td>
</tr>
<tr class="rowColor">
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.Space.html#%3Cinit%3E(com.google.common.collect.Multimap)">Space</a></span>&#8203;(com.google.common.collect.Multimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;&nbsp;providerMap)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr class="altColor">
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="../ReflectiveRelMetadataProvider.Space2.html#%3Cinit%3E(java.lang.Class,com.google.common.collect.ImmutableMultimap)">Space2</a></span>&#8203;(java.lang.Class&lt;<a href="../Metadata.html" title="interface in org.apache.calcite.rel.metadata">Metadata</a>&gt;&nbsp;metadataClass0,
com.google.common.collect.ImmutableMultimap&lt;java.lang.reflect.Method,&#8203;<a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">MetadataHandler</a>&gt;&nbsp;providerMap)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</tbody>
</table>
</section>
</li>
</ul>
</li>
</ul>
</div>
</main>
<footer role="contentinfo">
<nav role="navigation">
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a id="navbar.bottom">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.bottom.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../../index.html">Overview</a></li>
<li><a href="../package-summary.html">Package</a></li>
<li><a href="../MetadataHandler.html" title="interface in org.apache.calcite.rel.metadata">Class</a></li>
<li class="navBarCell1Rev">Use</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" id="allclasses_navbar_bottom">
<li><a href="../../../../../../allclasses.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>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</div>
<a id="skip.navbar.bottom">
<!-- -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</nav>
<p class="legalCopy"><small>Copyright &#169; 2012&#x2013;2019 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
</footer>
</body>
</html>