2018-09-26 17:39:21 +00:00
|
|
|
package tsm1
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
2019-01-08 00:37:16 +00:00
|
|
|
"github.com/influxdata/influxdb/models"
|
|
|
|
"github.com/influxdata/influxdb/pkg/metrics"
|
|
|
|
"github.com/influxdata/influxdb/query"
|
|
|
|
"github.com/influxdata/influxdb/tsdb"
|
|
|
|
"github.com/influxdata/influxdb/tsdb/cursors"
|
2018-09-26 17:39:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type arrayCursorIterator struct {
|
|
|
|
e *Engine
|
|
|
|
key []byte
|
|
|
|
|
|
|
|
asc struct {
|
|
|
|
Float *floatArrayAscendingCursor
|
|
|
|
Integer *integerArrayAscendingCursor
|
|
|
|
Unsigned *unsignedArrayAscendingCursor
|
|
|
|
Boolean *booleanArrayAscendingCursor
|
|
|
|
String *stringArrayAscendingCursor
|
|
|
|
}
|
|
|
|
|
|
|
|
desc struct {
|
|
|
|
Float *floatArrayDescendingCursor
|
|
|
|
Integer *integerArrayDescendingCursor
|
|
|
|
Unsigned *unsignedArrayDescendingCursor
|
|
|
|
Boolean *booleanArrayDescendingCursor
|
|
|
|
String *stringArrayDescendingCursor
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *arrayCursorIterator) Next(ctx context.Context, r *tsdb.CursorRequest) (tsdb.Cursor, error) {
|
2018-10-05 22:02:31 +00:00
|
|
|
q.key = tsdb.AppendSeriesKey(q.key[:0], r.Name, r.Tags)
|
|
|
|
id := q.e.sfile.SeriesIDTypedBySeriesKey(q.key)
|
|
|
|
if id.IsZero() {
|
2018-09-26 17:39:21 +00:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if grp := metrics.GroupFromContext(ctx); grp != nil {
|
|
|
|
grp.GetCounter(numberOfRefCursorsCounter).Add(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
var opt query.IteratorOptions
|
|
|
|
opt.Ascending = r.Ascending
|
|
|
|
opt.StartTime = r.StartTime
|
|
|
|
opt.EndTime = r.EndTime
|
|
|
|
|
|
|
|
// Return appropriate cursor based on type.
|
2018-10-05 22:02:31 +00:00
|
|
|
switch typ := id.Type(); typ {
|
|
|
|
case models.Float:
|
2018-09-26 17:39:21 +00:00
|
|
|
return q.buildFloatArrayCursor(ctx, r.Name, r.Tags, r.Field, opt), nil
|
2018-10-05 22:02:31 +00:00
|
|
|
case models.Integer:
|
2018-09-26 17:39:21 +00:00
|
|
|
return q.buildIntegerArrayCursor(ctx, r.Name, r.Tags, r.Field, opt), nil
|
2018-10-05 22:02:31 +00:00
|
|
|
case models.Unsigned:
|
2018-09-26 17:39:21 +00:00
|
|
|
return q.buildUnsignedArrayCursor(ctx, r.Name, r.Tags, r.Field, opt), nil
|
2018-10-05 22:02:31 +00:00
|
|
|
case models.String:
|
2018-09-26 17:39:21 +00:00
|
|
|
return q.buildStringArrayCursor(ctx, r.Name, r.Tags, r.Field, opt), nil
|
2018-10-05 22:02:31 +00:00
|
|
|
case models.Boolean:
|
2018-09-26 17:39:21 +00:00
|
|
|
return q.buildBooleanArrayCursor(ctx, r.Name, r.Tags, r.Field, opt), nil
|
|
|
|
default:
|
2018-10-05 22:02:31 +00:00
|
|
|
panic(fmt.Sprintf("unreachable: %v", typ))
|
2018-09-26 17:39:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *arrayCursorIterator) seriesFieldKeyBytes(name []byte, tags models.Tags, field string) []byte {
|
|
|
|
q.key = models.AppendMakeKey(q.key[:0], name, tags)
|
2019-02-18 12:47:29 +00:00
|
|
|
q.key = append(q.key, KeyFieldSeparatorBytes...)
|
2018-09-26 17:39:21 +00:00
|
|
|
q.key = append(q.key, field...)
|
|
|
|
return q.key
|
|
|
|
}
|
2018-11-07 16:31:42 +00:00
|
|
|
|
|
|
|
// Stats returns the cumulative stats for all cursors.
|
|
|
|
func (q *arrayCursorIterator) Stats() cursors.CursorStats {
|
|
|
|
var stats cursors.CursorStats
|
|
|
|
if cur := q.asc.Float; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.asc.Integer; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.asc.Unsigned; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.asc.Boolean; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.asc.String; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
}
|
|
|
|
if cur := q.desc.Float; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.desc.Integer; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.desc.Unsigned; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.desc.Boolean; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
} else if cur := q.desc.String; cur != nil {
|
|
|
|
stats.Add(cur.Stats())
|
|
|
|
}
|
|
|
|
return stats
|
|
|
|
}
|