diff --git a/lib/logstorage/parser_test.go b/lib/logstorage/parser_test.go index 68ac9a639..7c37230bd 100644 --- a/lib/logstorage/parser_test.go +++ b/lib/logstorage/parser_test.go @@ -1382,9 +1382,21 @@ func TestQueryGetNeededColumns(t *testing.T) { f(`* | sort by (f1) | sort by (f2,f3 desc) desc | fields f4 | rm f1,f2,f5`, `f1,f2,f3,f4`, ``) f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2`, `f1,f2,f3,f4`, ``) - f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2 | fields f1`, ``, ``) + f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2 | fields f5,f6`, ``, ``) + f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2 | fields f1,f5`, `f1`, ``) f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2 | fields r1`, `f1,f2`, ``) f(`* | stats by(f1) count(f2) r1, count(f3,f4) r2 | fields r2,r3`, `f1,f3,f4`, ``) + f(`_time:5m | stats by(_time:day) count() r1 | stats values(_time) r2`, `_time`, ``) + f(`* | stats count(f1) r1 | stats count() r1`, ``, ``) + f(`* | stats count(f1) r1 | stats count() r2`, ``, ``) + f(`* | stats count(f1) r1 | stats count(r1) r2`, `f1`, ``) + f(`* | stats count(f1) r1 | stats count(f1) r2`, ``, ``) + f(`* | stats count(f1) r1 | stats count(f1,r1) r1`, `f1`, ``) + f(`* | stats count(f1,f2) r1 | stats count(f2) r1, count(r1) r2`, `f1,f2`, ``) + f(`* | stats count(f1,f2) r1 | stats count(f2) r1, count(r1) r2 | fields r1`, ``, ``) + f(`* | stats count(f1,f2) r1 | stats count(f2) r1, count(r1) r2 | fields r2`, `f1,f2`, ``) + f(`* | stats by(f3,f4) count(f1,f2) r1 | stats count(f2) r1, count(r1) r2 | fields r2`, `f1,f2,f3,f4`, ``) + f(`* | stats by(f3,f4) count(f1,f2) r1 | stats count(f3) r1, count(r1) r2 | fields r1`, `f3,f4`, ``) f(`* | rm f1, f2`, `*`, `f1,f2`) f(`* | rm f1, f2 | mv f2 f3`, `*`, `f1,f2,f3`) diff --git a/lib/logstorage/pipe_stats.go b/lib/logstorage/pipe_stats.go index 0f81f6cfb..88a0bf8d3 100644 --- a/lib/logstorage/pipe_stats.go +++ b/lib/logstorage/pipe_stats.go @@ -92,6 +92,12 @@ func (ps *pipeStats) updateNeededFields(neededFields, unneededFields fieldsSet) byFields[i] = bf.name } + for _, f := range byFields { + if neededFieldsOrig.contains(f) && !unneededFields.contains(f) { + neededFields.addAll(byFields) + } + } + for i, resultName := range ps.resultNames { if neededFieldsOrig.contains(resultName) && !unneededFields.contains(resultName) { funcFields := ps.funcs[i].neededFields()