本文整理汇总了Golang中github.com/couchbase/query/algebra.KeyspaceTerm类的典型用法代码示例。如果您正苦于以下问题:Golang KeyspaceTerm类的具体用法?Golang KeyspaceTerm怎么用?Golang KeyspaceTerm使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了KeyspaceTerm类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: selectScan
func (this *builder) selectScan(keyspace datastore.Keyspace, node *algebra.KeyspaceTerm,
limit expression.Expression) (op plan.Operator, err error) {
keys := node.Keys()
if keys != nil {
switch keys := keys.(type) {
case *expression.ArrayConstruct:
this.maxParallelism = util.MaxInt(1, len(keys.Operands()))
case *algebra.NamedParameter, *algebra.PositionalParameter:
this.maxParallelism = 0
default:
this.maxParallelism = 1
}
return plan.NewKeyScan(keys), nil
}
this.maxParallelism = 0 // Use default parallelism for index scans
secondary, primary, err := this.buildScan(keyspace, node, limit)
if err != nil {
return nil, err
}
if secondary != nil {
return secondary, nil
} else {
return primary, nil
}
}
开发者ID:mschoch,项目名称:query,代码行数:29,代码来源:build_scan.go
示例2: buildCoveringJoinScan
func (this *builder) buildCoveringJoinScan(secondaries map[datastore.Index]*indexEntry,
node *algebra.KeyspaceTerm, op string) (datastore.Index, expression.Covers, error) {
if this.cover == nil {
for index, _ := range secondaries {
return index, nil, nil
}
}
alias := node.Alias()
exprs := this.cover.Expressions()
outer:
for index, entry := range secondaries {
for _, expr := range exprs {
if !expr.CoveredBy(alias, entry.keys) {
continue outer
}
}
covers := make(expression.Covers, len(entry.keys))
for i, key := range entry.keys {
covers[i] = expression.NewCover(key)
}
return index, covers, nil
}
for index, _ := range secondaries {
return index, nil, nil
}
return nil, nil, errors.NewNoIndexJoinError(node.Alias(), op)
}
开发者ID:pkdevboxy,项目名称:query,代码行数:33,代码来源:build_join_index.go
示例3: buildCoveringScan
func (this *builder) buildCoveringScan(secondaries map[datastore.Index]*indexEntry,
node *algebra.KeyspaceTerm, limit expression.Expression) (plan.Operator, error) {
if this.cover == nil {
return nil, nil
}
alias := node.Alias()
exprs := this.cover.Expressions()
id := expression.NewField(
expression.NewMeta(expression.NewIdentifier(node.Alias())),
expression.NewFieldName("id", false))
outer:
for index, entry := range secondaries {
keys := entry.keys
if !index.IsPrimary() {
// Matches execution.spanScan.RunOnce()
keys = append(keys, id)
}
// Use the first available covering index
for _, expr := range exprs {
if !expr.CoveredBy(alias, keys) {
continue outer
}
}
covers := make(expression.Covers, 0, len(keys))
for _, key := range keys {
covers = append(covers, expression.NewCover(key))
}
scan := plan.NewIndexScan(index, node, entry.spans, false, limit, covers)
this.coveringScan = scan
if len(entry.spans) > 1 {
// Use UnionScan to de-dup multiple spans
return plan.NewUnionScan(scan), nil
}
return scan, nil
}
return nil, nil
}
开发者ID:pkdevboxy,项目名称:query,代码行数:45,代码来源:build_scan.go
示例4: VisitKeyspaceTerm
func (this *builder) VisitKeyspaceTerm(node *algebra.KeyspaceTerm) (interface{}, error) {
node.SetDefaultNamespace(this.namespace)
keyspace, err := this.getTermKeyspace(node)
if err != nil {
return nil, err
}
if this.subquery && this.correlated && node.Keys() == nil {
return nil, errors.NewSubqueryMissingKeysError(node.Keyspace())
}
scan, err := this.selectScan(keyspace, node, this.limit)
if err != nil {
return nil, err
}
this.children = append(this.children, scan)
if this.coveringScan == nil {
fetch := plan.NewFetch(keyspace, node)
this.subChildren = append(this.subChildren, fetch)
}
return nil, nil
}
开发者ID:pkdevboxy,项目名称:query,代码行数:25,代码来源:build_select_from.go
示例5: buildJoinScan
func (this *builder) buildJoinScan(keyspace datastore.Keyspace, node *algebra.KeyspaceTerm, op string) (
datastore.Index, expression.Covers, error) {
indexes, err := allIndexes(keyspace)
if err != nil {
return nil, nil, err
}
var pred expression.Expression
pred = expression.NewIsNotNull(node.Keys().Copy())
dnf := NewDNF()
pred, err = dnf.Map(pred)
if err != nil {
return nil, nil, err
}
subset := pred
if this.where != nil {
subset = expression.NewAnd(subset, this.where.Copy())
subset, err = dnf.Map(subset)
if err != nil {
return nil, nil, err
}
}
formalizer := expression.NewFormalizer()
formalizer.Keyspace = node.Alias()
primaryKey := expression.Expressions{
expression.NewField(
expression.NewMeta(expression.NewConstant(node.Alias())),
expression.NewFieldName("id", false)),
}
sargables, err := sargableIndexes(indexes, pred, subset, primaryKey, dnf, formalizer)
if err != nil {
return nil, nil, err
}
minimals, err := minimalIndexes(sargables, pred)
if err != nil {
return nil, nil, err
}
if len(minimals) == 0 {
return nil, nil, errors.NewNoIndexJoinError(node.Alias(), op)
}
return this.buildCoveringJoinScan(minimals, node, op)
}
开发者ID:jmptrader,项目名称:query,代码行数:48,代码来源:build_join_index.go
示例6: buildScan
func (this *builder) buildScan(keyspace datastore.Keyspace, node *algebra.KeyspaceTerm, limit expression.Expression) (
secondary plan.Operator, primary *plan.PrimaryScan, err error) {
var indexes, hintIndexes, otherIndexes []datastore.Index
hints := node.Indexes()
if hints != nil {
indexes, err = allHints(keyspace, hints)
hintIndexes = indexes
} else {
indexes, err = allIndexes(keyspace)
otherIndexes = indexes
}
if err != nil {
return
}
pred := this.where
if pred != nil {
dnf := NewDNF()
pred = pred.Copy()
pred, err = dnf.Map(pred)
if err != nil {
return
}
formalizer := expression.NewFormalizer()
formalizer.Keyspace = node.Alias()
primaryKey := expression.Expressions{
expression.NewField(
expression.NewMeta(expression.NewConstant(node.Alias())),
expression.NewFieldName("id", false)),
}
sargables, er := sargableIndexes(indexes, pred, primaryKey, dnf, formalizer)
if er != nil {
return nil, nil, er
}
minimals, er := minimalIndexes(sargables, pred)
if er != nil {
return nil, nil, er
}
if len(minimals) > 0 {
secondary, err = this.buildSecondaryScan(minimals, node, limit)
return secondary, nil, err
}
}
primary, err = this.buildPrimaryScan(keyspace, node, limit, hintIndexes, otherIndexes)
return nil, primary, err
}
开发者ID:mschoch,项目名称:query,代码行数:52,代码来源:build_scan.go
示例7: getTermKeyspace
func (this *builder) getTermKeyspace(node *algebra.KeyspaceTerm) (datastore.Keyspace, error) {
node.SetDefaultNamespace(this.namespace)
ns := node.Namespace()
datastore := this.datastore
if strings.ToLower(ns) == "#system" {
datastore = this.systemstore
}
namespace, err := datastore.NamespaceByName(ns)
if err != nil {
return nil, err
}
keyspace, err := namespace.KeyspaceByName(node.Keyspace())
if err != nil {
return nil, err
}
return keyspace, nil
}
开发者ID:pkdevboxy,项目名称:query,代码行数:21,代码来源:build.go
注:本文中的github.com/couchbase/query/algebra.KeyspaceTerm类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论