2018-03-11 00:15:26 +00:00
|
|
|
#pragma once
|
|
|
|
|
2020-03-19 10:38:34 +00:00
|
|
|
#include <common/types.h>
|
2018-03-11 00:15:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
/// What to do if the limit is exceeded.
|
|
|
|
enum class OverflowMode
|
|
|
|
{
|
|
|
|
THROW = 0, /// Throw exception.
|
|
|
|
BREAK = 1, /// Abort query execution, return what is.
|
|
|
|
|
|
|
|
/** Only for GROUP BY: do not add new rows to the set,
|
|
|
|
* but continue to aggregate for keys that are already in the set.
|
|
|
|
*/
|
|
|
|
ANY = 2,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct SizeLimits
|
|
|
|
{
|
|
|
|
/// If it is zero, corresponding limit check isn't performed.
|
|
|
|
UInt64 max_rows = 0;
|
|
|
|
UInt64 max_bytes = 0;
|
|
|
|
OverflowMode overflow_mode = OverflowMode::THROW;
|
|
|
|
|
|
|
|
SizeLimits() {}
|
2019-08-03 11:02:40 +00:00
|
|
|
SizeLimits(UInt64 max_rows_, UInt64 max_bytes_, OverflowMode overflow_mode_)
|
|
|
|
: max_rows(max_rows_), max_bytes(max_bytes_), overflow_mode(overflow_mode_) {}
|
2018-03-11 00:15:26 +00:00
|
|
|
|
|
|
|
/// Check limits. If exceeded, return false or throw an exception, depending on overflow_mode.
|
2019-10-03 18:27:11 +00:00
|
|
|
bool check(UInt64 rows, UInt64 bytes, const char * what, int too_many_rows_exception_code, int too_many_bytes_exception_code) const;
|
2018-03-11 00:15:26 +00:00
|
|
|
bool check(UInt64 rows, UInt64 bytes, const char * what, int exception_code) const;
|
2019-10-15 16:31:49 +00:00
|
|
|
|
|
|
|
/// Check limits. No exceptions.
|
|
|
|
bool softCheck(UInt64 rows, UInt64 bytes) const;
|
|
|
|
|
|
|
|
bool hasLimits() const { return max_rows || max_bytes; }
|
2018-03-11 00:15:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|