blob: c8b37d8c9fd8da2bbbfdce4ef65093daa9a330b0 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html lang="zh">
<head>
<!-- Generated by javadoc -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RelMdPredicates (Apache Calcite calcite API)</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="RelMdPredicates (Apache Calcite calcite API)";
}
}
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};
var tabs = {65535:["t0","所有方法"],2:["t2","实例方法"],8:["t4","具体方法"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
</script>
<noscript>
<div>您的浏览器已禁用 JavaScript。</div>
</noscript>
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a name="navbar.top">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="跳过导航链接">跳过导航链接</a></div>
<a name="navbar.top.firstrow">
<!-- -->
</a>
<ul class="navList" title="导航">
<li><a href="../../../../../overview-summary.html">概览</a></li>
<li><a href="package-summary.html">程序包</a></li>
<li class="navBarCell1Rev"></li>
<li><a href="package-tree.html"></a></li>
<li><a href="../../../../../deprecated-list.html">已过时</a></li>
<li><a href="../../../../../index-all.html">索引</a></li>
<li><a href="../../../../../help-doc.html">帮助</a></li>
</ul>
<div class="aboutLanguage"><b>Apache Calcite</b></div>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPopulationSize.html" title="org.apache.calcite.rel.metadata中的类"><span class="typeNameLink">上一个类</span></a></li>
<li><a href="../../../../../org/apache/calcite/rel/metadata/RelMdRowCount.html" title="org.apache.calcite.rel.metadata中的类"><span class="typeNameLink">下一个类</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/calcite/rel/metadata/RelMdPredicates.html" target="_top">框架</a></li>
<li><a href="RelMdPredicates.html" target="_top">无框架</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../../../allclasses-noframe.html">所有类</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>概要:&nbsp;</li>
<li>嵌套&nbsp;|&nbsp;</li>
<li><a href="#field.summary">字段</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">构造器</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">方法</a></li>
</ul>
<ul class="subNavList">
<li>详细资料:&nbsp;</li>
<li><a href="#field.detail">字段</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">构造器</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">方法</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.calcite.rel.metadata</div>
<h2 title="类 RelMdPredicates" class="title">类 RelMdPredicates</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="java.lang中的类或接口">java.lang.Object</a></li>
<li>
<ul class="inheritance">
<li>org.apache.calcite.rel.metadata.RelMdPredicates</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>所有已实现的接口:</dt>
<dd><a href="../../../../../org/apache/calcite/rel/metadata/MetadataHandler.html" title="org.apache.calcite.rel.metadata中的接口">MetadataHandler</a>&lt;<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html" title="org.apache.calcite.rel.metadata中的接口">BuiltInMetadata.Predicates</a>&gt;</dd>
</dl>
<hr>
<br>
<pre>public class <span class="typeNameLabel">RelMdPredicates</span>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="java.lang中的类或接口">Object</a>
implements <a href="../../../../../org/apache/calcite/rel/metadata/MetadataHandler.html" title="org.apache.calcite.rel.metadata中的接口">MetadataHandler</a>&lt;<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html" title="org.apache.calcite.rel.metadata中的接口">BuiltInMetadata.Predicates</a>&gt;</pre>
<div class="block">Utility to infer Predicates that are applicable above a RelNode.
<p>This is currently used by
<a href="../../../../../org/apache/calcite/rel/rules/JoinPushTransitivePredicatesRule.html" title="org.apache.calcite.rel.rules中的类"><code>JoinPushTransitivePredicatesRule</code></a> to
infer <em>Predicates</em> that can be inferred from one side of a Join
to the other.
<p>The PullUp Strategy is sound but not complete. Here are some of the
limitations:
<ol>
<li> For Aggregations we only PullUp predicates that only contain
Grouping Keys. This can be extended to infer predicates on Aggregation
expressions from expressions on the aggregated columns. For e.g.
<pre>
select a, max(b) from R1 where b &gt; 7
&rarr; max(b) &gt; 7 or max(b) is null
</pre>
<li> For Projections we only look at columns that are projected without
any function applied. So:
<pre>
select a from R1 where a &gt; 7
&rarr; "a &gt; 7" is pulled up from the Projection.
select a + 1 from R1 where a + 1 &gt; 7
&rarr; "a + 1 gt; 7" is not pulled up
</pre>
<li> There are several restrictions on Joins:
<ul>
<li> We only pullUp inferred predicates for now. Pulling up existing
predicates causes an explosion of duplicates. The existing predicates
are pushed back down as new predicates. Once we have rules to eliminate
duplicate Filter conditions, we should pullUp all predicates.
<li> For Left Outer: we infer new predicates from the left and set them
as applicable on the Right side. No predicates are pulledUp.
<li> Right Outer Joins are handled in an analogous manner.
<li> For Full Outer Joins no predicates are pulledUp or inferred.
</ul>
</ol></div>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- =========== FIELD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="field.summary">
<!-- -->
</a>
<h3>字段概要</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="字段概要表, 列表字段和解释">
<caption><span>字段</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">限定符和类型</th>
<th class="colLast" scope="col">字段和说明</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataProvider.html" title="org.apache.calcite.rel.metadata中的接口">RelMetadataProvider</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#SOURCE">SOURCE</a></span></code>&nbsp;</td>
</tr>
</table>
</li>
</ul>
<!-- ======== CONSTRUCTOR SUMMARY ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.summary">
<!-- -->
</a>
<h3>构造器概要</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="构造器概要表, 列表构造器和解释">
<caption><span>构造器</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colOne" scope="col">构造器和说明</th>
</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#RelMdPredicates--">RelMdPredicates</a></span>()</code>&nbsp;</td>
</tr>
</table>
</li>
</ul>
<!-- ========== METHOD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="method.summary">
<!-- -->
</a>
<h3>方法概要</h3>
<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="方法概要表, 列表方法和解释">
<caption><span id="t0" class="activeTableTab"><span>所有方法</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">实例方法</a></span><span class="tabEnd">&nbsp;</span></span><span id="t4" class="tableTab"><span><a href="javascript:show(8);">具体方法</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">限定符和类型</th>
<th class="colLast" scope="col">方法和说明</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/rel/metadata/MetadataDef.html" title="org.apache.calcite.rel.metadata中的类">MetadataDef</a>&lt;<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html" title="org.apache.calcite.rel.metadata中的接口">BuiltInMetadata.Predicates</a>&gt;</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getDef--">getDef</a></span>()</code>&nbsp;</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Aggregate-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Aggregate.html" title="org.apache.calcite.rel.core中的类">Aggregate</a>&nbsp;agg,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for an Aggregate.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Exchange-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Exchange.html" title="org.apache.calcite.rel.core中的类">Exchange</a>&nbsp;exchange,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for an Exchange.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Filter-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Filter.html" title="org.apache.calcite.rel.core中的类">Filter</a>&nbsp;filter,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Add the Filter condition to the pulledPredicates list from the input.</div>
</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.plan.hep.HepRelVertex-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/plan/hep/HepRelVertex.html" title="org.apache.calcite.plan.hep中的类">HepRelVertex</a>&nbsp;rel,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>&nbsp;</td>
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Intersect-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Intersect.html" title="org.apache.calcite.rel.core中的类">Intersect</a>&nbsp;intersect,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a Intersect.</div>
</td>
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Join-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Join.html" title="org.apache.calcite.rel.core中的类">Join</a>&nbsp;join,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a <a href="../../../../../org/apache/calcite/rel/core/Join.html" title="org.apache.calcite.rel.core中的类"><code>Join</code></a> (including
<code>SemiJoin</code>).</div>
</td>
</tr>
<tr id="i7" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Minus-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Minus.html" title="org.apache.calcite.rel.core中的类">Minus</a>&nbsp;minus,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a Minus.</div>
</td>
</tr>
<tr id="i8" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Project-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Project.html" title="org.apache.calcite.rel.core中的类">Project</a>&nbsp;project,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a project.</div>
</td>
</tr>
<tr id="i9" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.RelNode-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/RelNode.html" title="org.apache.calcite.rel中的接口">RelNode</a>&nbsp;rel,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Catch-all implementation for
<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html#getPredicates--"><code>BuiltInMetadata.Predicates.getPredicates()</code></a>,
invoked using reflection.</div>
</td>
</tr>
<tr id="i10" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.plan.volcano.RelSubset-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/plan/volcano/RelSubset.html" title="org.apache.calcite.plan.volcano中的类">RelSubset</a>&nbsp;r,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>&nbsp;</td>
</tr>
<tr id="i11" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Sort-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Sort.html" title="org.apache.calcite.rel.core中的类">Sort</a>&nbsp;sort,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a Sort.</div>
</td>
</tr>
<tr id="i12" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.TableModify-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/TableModify.html" title="org.apache.calcite.rel.core中的类">TableModify</a>&nbsp;tableModify,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a TableModify.</div>
</td>
</tr>
<tr id="i13" class="rowColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.TableScan-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/TableScan.html" title="org.apache.calcite.rel.core中的类">TableScan</a>&nbsp;table,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a table scan.</div>
</td>
</tr>
<tr id="i14" class="altColor">
<td class="colFirst"><code><a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPredicates.html#getPredicates-org.apache.calcite.rel.core.Union-org.apache.calcite.rel.metadata.RelMetadataQuery-">getPredicates</a></span>(<a href="../../../../../org/apache/calcite/rel/core/Union.html" title="org.apache.calcite.rel.core中的类">Union</a>&nbsp;union,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</code>
<div class="block">Infers predicates for a Union.</div>
</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
<!-- -->
</a>
<h3>从类继承的方法&nbsp;java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="java.lang中的类或接口">Object</a></h3>
<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#clone--" title="java.lang中的类或接口">clone</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#equals-java.lang.Object-" title="java.lang中的类或接口">equals</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#finalize--" title="java.lang中的类或接口">finalize</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#getClass--" title="java.lang中的类或接口">getClass</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#hashCode--" title="java.lang中的类或接口">hashCode</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notify--" title="java.lang中的类或接口">notify</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notifyAll--" title="java.lang中的类或接口">notifyAll</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#toString--" title="java.lang中的类或接口">toString</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait--" title="java.lang中的类或接口">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-" title="java.lang中的类或接口">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-int-" title="java.lang中的类或接口">wait</a></code></li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ FIELD DETAIL =========== -->
<ul class="blockList">
<li class="blockList"><a name="field.detail">
<!-- -->
</a>
<h3>字段详细资料</h3>
<a name="SOURCE">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>SOURCE</h4>
<pre>public static final&nbsp;<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataProvider.html" title="org.apache.calcite.rel.metadata中的接口">RelMetadataProvider</a> SOURCE</pre>
</li>
</ul>
</li>
</ul>
<!-- ========= CONSTRUCTOR DETAIL ======== -->
<ul class="blockList">
<li class="blockList"><a name="constructor.detail">
<!-- -->
</a>
<h3>构造器详细资料</h3>
<a name="RelMdPredicates--">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>RelMdPredicates</h4>
<pre>public&nbsp;RelMdPredicates()</pre>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method.detail">
<!-- -->
</a>
<h3>方法详细资料</h3>
<a name="getDef--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getDef</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/rel/metadata/MetadataDef.html" title="org.apache.calcite.rel.metadata中的类">MetadataDef</a>&lt;<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html" title="org.apache.calcite.rel.metadata中的接口">BuiltInMetadata.Predicates</a>&gt;&nbsp;getDef()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">指定者:</span></dt>
<dd><code><a href="../../../../../org/apache/calcite/rel/metadata/MetadataHandler.html#getDef--">getDef</a></code>&nbsp;在接口中&nbsp;<code><a href="../../../../../org/apache/calcite/rel/metadata/MetadataHandler.html" title="org.apache.calcite.rel.metadata中的接口">MetadataHandler</a>&lt;<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html" title="org.apache.calcite.rel.metadata中的接口">BuiltInMetadata.Predicates</a>&gt;</code></dd>
</dl>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.RelNode-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/RelNode.html" title="org.apache.calcite.rel中的接口">RelNode</a>&nbsp;rel,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Catch-all implementation for
<a href="../../../../../org/apache/calcite/rel/metadata/BuiltInMetadata.Predicates.html#getPredicates--"><code>BuiltInMetadata.Predicates.getPredicates()</code></a>,
invoked using reflection.</div>
<dl>
<dt><span class="seeLabel">另请参阅:</span></dt>
<dd><a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html#getPulledUpPredicates-org.apache.calcite.rel.RelNode-"><code>RelMetadataQuery.getPulledUpPredicates(RelNode)</code></a></dd>
</dl>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.plan.hep.HepRelVertex-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/plan/hep/HepRelVertex.html" title="org.apache.calcite.plan.hep中的类">HepRelVertex</a>&nbsp;rel,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.TableScan-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/TableScan.html" title="org.apache.calcite.rel.core中的类">TableScan</a>&nbsp;table,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a table scan.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Project-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Project.html" title="org.apache.calcite.rel.core中的类">Project</a>&nbsp;project,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a project.
<ol>
<li>create a mapping from input to projection. Map only positions that
directly reference an input column.
<li>Expressions that only contain above columns are retained in the
Project's pullExpressions list.
<li>For e.g. expression 'a + e = 9' below will not be pulled up because 'e'
is not in the projection list.
<blockquote><pre>
inputPullUpExprs: {a &gt; 7, b + c &lt; 10, a + e = 9}
projectionExprs: {a, b, c, e / 2}
projectionPullupExprs: {a &gt; 7, b + c &lt; 10}
</pre></blockquote>
</ol></div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Filter-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Filter.html" title="org.apache.calcite.rel.core中的类">Filter</a>&nbsp;filter,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Add the Filter condition to the pulledPredicates list from the input.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Join-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Join.html" title="org.apache.calcite.rel.core中的类">Join</a>&nbsp;join,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a <a href="../../../../../org/apache/calcite/rel/core/Join.html" title="org.apache.calcite.rel.core中的类"><code>Join</code></a> (including
<code>SemiJoin</code>).</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Aggregate-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Aggregate.html" title="org.apache.calcite.rel.core中的类">Aggregate</a>&nbsp;agg,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for an Aggregate.
<p>Pulls up predicates that only contains references to columns in the
GroupSet. For e.g.
<blockquote><pre>
inputPullUpExprs : { a &gt; 7, b + c &lt; 10, a + e = 9}
groupSet : { a, b}
pulledUpExprs : { a &gt; 7}
</pre></blockquote></div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Union-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Union.html" title="org.apache.calcite.rel.core中的类">Union</a>&nbsp;union,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a Union.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Intersect-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Intersect.html" title="org.apache.calcite.rel.core中的类">Intersect</a>&nbsp;intersect,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a Intersect.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Minus-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Minus.html" title="org.apache.calcite.rel.core中的类">Minus</a>&nbsp;minus,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a Minus.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Sort-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Sort.html" title="org.apache.calcite.rel.core中的类">Sort</a>&nbsp;sort,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a Sort.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.TableModify-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/TableModify.html" title="org.apache.calcite.rel.core中的类">TableModify</a>&nbsp;tableModify,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for a TableModify.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.rel.core.Exchange-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/rel/core/Exchange.html" title="org.apache.calcite.rel.core中的类">Exchange</a>&nbsp;exchange,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<div class="block">Infers predicates for an Exchange.</div>
</li>
</ul>
<a name="getPredicates-org.apache.calcite.plan.volcano.RelSubset-org.apache.calcite.rel.metadata.RelMetadataQuery-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>getPredicates</h4>
<pre>public&nbsp;<a href="../../../../../org/apache/calcite/plan/RelOptPredicateList.html" title="org.apache.calcite.plan中的类">RelOptPredicateList</a>&nbsp;getPredicates(<a href="../../../../../org/apache/calcite/plan/volcano/RelSubset.html" title="org.apache.calcite.plan.volcano中的类">RelSubset</a>&nbsp;r,
<a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html" title="org.apache.calcite.rel.metadata中的类">RelMetadataQuery</a>&nbsp;mq)</pre>
<dl>
<dt><span class="seeLabel">另请参阅:</span></dt>
<dd><a href="../../../../../org/apache/calcite/rel/metadata/RelMetadataQuery.html#getPulledUpPredicates-org.apache.calcite.rel.RelNode-"><code>RelMetadataQuery.getPulledUpPredicates(RelNode)</code></a></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="跳过导航链接">跳过导航链接</a></div>
<a name="navbar.bottom.firstrow">
<!-- -->
</a>
<ul class="navList" title="导航">
<li><a href="../../../../../overview-summary.html">概览</a></li>
<li><a href="package-summary.html">程序包</a></li>
<li class="navBarCell1Rev"></li>
<li><a href="package-tree.html"></a></li>
<li><a href="../../../../../deprecated-list.html">已过时</a></li>
<li><a href="../../../../../index-all.html">索引</a></li>
<li><a href="../../../../../help-doc.html">帮助</a></li>
</ul>
<div class="aboutLanguage"><b>Apache Calcite</b></div>
</div>
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/calcite/rel/metadata/RelMdPopulationSize.html" title="org.apache.calcite.rel.metadata中的类"><span class="typeNameLink">上一个类</span></a></li>
<li><a href="../../../../../org/apache/calcite/rel/metadata/RelMdRowCount.html" title="org.apache.calcite.rel.metadata中的类"><span class="typeNameLink">下一个类</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/calcite/rel/metadata/RelMdPredicates.html" target="_top">框架</a></li>
<li><a href="RelMdPredicates.html" target="_top">无框架</a></li>
</ul>
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../../../allclasses-noframe.html">所有类</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>概要:&nbsp;</li>
<li>嵌套&nbsp;|&nbsp;</li>
<li><a href="#field.summary">字段</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.summary">构造器</a>&nbsp;|&nbsp;</li>
<li><a href="#method.summary">方法</a></li>
</ul>
<ul class="subNavList">
<li>详细资料:&nbsp;</li>
<li><a href="#field.detail">字段</a>&nbsp;|&nbsp;</li>
<li><a href="#constructor.detail">构造器</a>&nbsp;|&nbsp;</li>
<li><a href="#method.detail">方法</a></li>
</ul>
</div>
<a name="skip.navbar.bottom">
<!-- -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
<p class="legalCopy"><small>Copyright &copy; 2012-2020 Apache Software Foundation. All Rights Reserved.</small></p>
</body>
</html>