This commit is contained in:
Aliaksandr Valialkin 2024-05-06 23:46:00 +02:00
parent 9f33220e51
commit 866c070f32
No known key found for this signature in database
GPG key ID: 52C003EE2BCDB9EB

View file

@ -188,17 +188,16 @@ func (shard *pipeSortProcessorShard) writeBlock(br *blockResult) {
byColumnsBufLen := len(byColumnsBuf) byColumnsBufLen := len(byColumnsBuf)
for _, bf := range byFields { for _, bf := range byFields {
c := br.getColumnByName(bf.name) c := br.getColumnByName(bf.name)
values := c.getValues(br) byColumnsBuf = append(byColumnsBuf, sortBlockByColumn{})
values = shard.copyValues(values) bc := &byColumnsBuf[len(byColumnsBuf)-1]
u64Values := shard.createUint64Values(values) if c.isTime {
f64Values := shard.createFloat64Values(values) bc.timestamps = shard.copyTimestamps(br.timestamps)
timestamps := shard.createTimestampsIfNeeded(br.timestamps, c.isTime) } else {
byColumnsBuf = append(byColumnsBuf, sortBlockByColumn{ values := c.getValues(br)
values: values, bc.values = shard.copyValues(values)
u64Values: u64Values, bc.u64Values = shard.createUint64Values(values)
f64Values: f64Values, bc.f64Values = shard.createFloat64Values(values)
timestamps: timestamps, }
})
} }
shard.byColumnsBuf = byColumnsBuf shard.byColumnsBuf = byColumnsBuf
byColumns := byColumnsBuf[byColumnsBufLen:] byColumns := byColumnsBuf[byColumnsBufLen:]
@ -312,11 +311,7 @@ func (shard *pipeSortProcessorShard) createFloat64Values(values []string) []floa
return f64ValuesBuf[f64ValuesBufLen:] return f64ValuesBuf[f64ValuesBufLen:]
} }
func (shard *pipeSortProcessorShard) createTimestampsIfNeeded(timestamps []int64, isTime bool) []int64 { func (shard *pipeSortProcessorShard) copyTimestamps(timestamps []int64) []int64 {
if !isTime {
return nil
}
timestampsBuf := shard.timestampsBuf timestampsBuf := shard.timestampsBuf
timestampsBufLen := len(shard.timestampsBuf) timestampsBufLen := len(shard.timestampsBuf)
timestampsBuf = append(timestampsBuf, timestamps...) timestampsBuf = append(timestampsBuf, timestamps...)
@ -461,9 +456,12 @@ func (psp *pipeSortProcessor) flush() error {
} }
type pipeSortWriteContext struct { type pipeSortWriteContext struct {
psp *pipeSortProcessor psp *pipeSortProcessor
rcs []resultColumn rcs []resultColumn
br blockResult br blockResult
auxBuf []byte
valuesLen int valuesLen int
} }
@ -502,11 +500,20 @@ func (wctx *pipeSortWriteContext) writeRow(shard *pipeSortProcessorShard, rowIdx
} }
byColumns := b.byColumns byColumns := b.byColumns
auxBuf := wctx.auxBuf
for i := range byFields { for i := range byFields {
v := byColumns[i].values[rr.rowIdx] bc := &byColumns[i]
rcs[i].addValue(v) if len(bc.timestamps) > 0 {
wctx.valuesLen += len(v) auxBuf = marshalTimestampISO8601(auxBuf[:0], bc.timestamps[rr.rowIdx])
rcs[i].addValue(bytesutil.ToUnsafeString(auxBuf))
wctx.valuesLen += len(auxBuf)
} else {
v := bc.values[rr.rowIdx]
rcs[i].addValue(v)
wctx.valuesLen += len(v)
}
} }
wctx.auxBuf = auxBuf
otherColumns := b.otherColumns otherColumns := b.otherColumns
for i := range otherColumns { for i := range otherColumns {
@ -594,6 +601,14 @@ func sortBlockLess(shardA *pipeSortProcessorShard, rowIdxA uint, shardB *pipeSor
} }
return tA < tB return tA < tB
} }
if len(cA.timestamps) > 0 {
// treat timestamps as smaller than other values
return true
}
if len(cB.timestamps) > 0 {
// treat timestamps as smaller than other values
return false
}
// Try sorting by uint64 values at first // Try sorting by uint64 values at first
uA := cA.u64Values[rrA.rowIdx] uA := cA.u64Values[rrA.rowIdx]