Files
tidb/pkg/planner/core/explain.go

73 lines
2.2 KiB
Go

// Copyright 2017 PingCAP, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package core
import (
"strconv"
"strings"
)
// ExplainInfo implements Plan interface.
func (p *PhysicalIndexReader) ExplainInfo() string {
return "index:" + p.indexPlan.ExplainID().String()
}
// ExplainNormalizedInfo implements Plan interface.
func (p *PhysicalIndexReader) ExplainNormalizedInfo() string {
return "index:" + p.indexPlan.TP()
}
// ExplainInfo implements Plan interface.
func (p *PhysicalIndexLookUpReader) ExplainInfo() string {
var str strings.Builder
// The children can be inferred by the relation symbol.
if p.PushedLimit != nil {
str.WriteString("limit embedded(offset:")
str.WriteString(strconv.FormatUint(p.PushedLimit.Offset, 10))
str.WriteString(", count:")
str.WriteString(strconv.FormatUint(p.PushedLimit.Count, 10))
str.WriteString(")")
}
return str.String()
}
// ExplainInfo implements Plan interface.
func (p *PhysicalIndexMergeReader) ExplainInfo() string {
var str strings.Builder
if p.IsIntersectionType {
str.WriteString("type: intersection")
} else {
str.WriteString("type: union")
}
if p.PushedLimit != nil {
str.WriteString(", limit embedded(offset:")
str.WriteString(strconv.FormatUint(p.PushedLimit.Offset, 10))
str.WriteString(", count:")
str.WriteString(strconv.FormatUint(p.PushedLimit.Count, 10))
str.WriteString(")")
}
return str.String()
}
// ExplainInfo implements Plan interface.
func (p *PhysicalIndexMergeJoin) ExplainInfo() string {
return p.PhysicalIndexJoin.ExplainInfoInternal(false, true)
}
// ExplainNormalizedInfo implements Plan interface.
func (p *PhysicalIndexMergeJoin) ExplainNormalizedInfo() string {
return p.PhysicalIndexJoin.ExplainInfoInternal(true, true)
}