aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/clickhouse/src/Planner/PlannerWindowFunctions.h
blob: 1552ef5a71f41f311bb303c8ecf4cd9ec48b2dad (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#pragma once

#include <Core/SortDescription.h>

#include <Planner/PlannerContext.h>

#include <Interpreters/WindowDescription.h>

namespace DB
{

/// Extract window descriptions from window function nodes
std::vector<WindowDescription> extractWindowDescriptions(const QueryTreeNodes & window_function_nodes, const PlannerContext & planner_context);

/** Try to sort window descriptions in such an order that the window with the longest
  * sort description goes first, and all window that use its prefixes follow.
  */
void sortWindowDescriptions(std::vector<WindowDescription> & window_descriptions);

}