mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-02 12:32:04 +00:00
b680697cce
The cost of initializing members is insignificant in compare to parsing, while the cost of the error is high. Signed-off-by: Azat Khuzhin <a.khuzhin@semrush.com>
42 lines
1.0 KiB
C++
42 lines
1.0 KiB
C++
#pragma once
|
|
|
|
#include <Parsers/IAST.h>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
/** Element of expression with ASC or DESC,
|
|
* and possibly with COLLATE.
|
|
*/
|
|
class ASTOrderByElement : public IAST
|
|
{
|
|
public:
|
|
int direction = 0; /// 1 for ASC, -1 for DESC
|
|
int nulls_direction = 0; /// Same as direction for NULLS LAST, opposite for NULLS FIRST.
|
|
bool nulls_direction_was_explicitly_specified = false;
|
|
|
|
/** Collation for locale-specific string comparison. If empty, then sorting done by bytes. */
|
|
ASTPtr collation;
|
|
|
|
bool with_fill = false;
|
|
ASTPtr fill_from;
|
|
ASTPtr fill_to;
|
|
ASTPtr fill_step;
|
|
|
|
String getID(char) const override { return "OrderByElement"; }
|
|
|
|
ASTPtr clone() const override
|
|
{
|
|
auto clone = std::make_shared<ASTOrderByElement>(*this);
|
|
clone->cloneChildren();
|
|
return clone;
|
|
}
|
|
|
|
void updateTreeHashImpl(SipHash & hash_state) const override;
|
|
|
|
protected:
|
|
void formatImpl(const FormatSettings & settings, FormatState & state, FormatStateStacked frame) const override;
|
|
};
|
|
|
|
}
|