Definition at line 514 of file DdlUtils.cpp.
References CHECK, convert_decimal_value_to_scale(), Geospatial::GeoTypesFactory::createGeoType(), SQLTypeInfo::get_elem_type(), SQLTypeInfo::get_size(), SQLTypeInfo::get_type(), kARRAY, kBIGINT, kBOOLEAN, kCHAR, kDATE, kDECIMAL, kDOUBLE, kFLOAT, kINT, Geospatial::GeoBase::kLINESTRING, kLINESTRING, Geospatial::GeoBase::kMULTIPOLYGON, kMULTIPOLYGON, kNUMERIC, Geospatial::GeoBase::kPOINT, kPOINT, Geospatial::GeoBase::kPOLYGON, kPOLYGON, kSMALLINT, kTEXT, kTIME, kTIMESTAMP, kTINYINT, kVARCHAR, StringDictionary::MAX_STRLEN, split(), StringToDatum(), to_string(), to_upper(), DecimalOverflowValidator::validate(), and DateDaysOverflowValidator::validate().
Referenced by ddl_utils::validate_and_set_default_value().
535 validator.validate(d.bigintval);
544 validator.validate(converted_val);
551 throw std::runtime_error(
"String too long for column " + column_name +
" was " +
557 if (val.front() !=
'{' || val.back() !=
'}') {
558 throw std::runtime_error(column_name +
559 ": arrays should start and end with curly braces");
561 std::vector<std::string> elements =
split(val.substr(1, val.length() - 2),
", ");
564 size_t expected_size = column_type.
get_size() / sti.get_size();
565 size_t actual_size = elements.size();
566 if (actual_size != expected_size) {
567 throw std::runtime_error(
"Fixed length array column " + column_name +
573 for (
const auto& element : elements) {
590 throw std::runtime_error(
"Unexpected geo literal '" + val +
"' for column " +
593 if (!geo->transform(column_type)) {
594 throw std::runtime_error(
"Cannot transform SRID for literal '" + val +
595 "' for column " + column_name);
597 auto sql_type = column_type.
get_type();
598 auto geo_type = geo->getType();
606 throw std::runtime_error(
"Geo literal '" + val +
607 "' doesn't match the type "
608 "of column column " +
613 throw std::runtime_error(
"Unexpected geo literal '" + val +
"' for column " +
614 column_name +
": " + e.what());
618 CHECK(
false) <<
"validate_literal() does not support type "
static std::unique_ptr< GeoBase > createGeoType(const std::string &wkt_or_wkb_hex)
HOST DEVICE int get_size() const
void validate_literal(const std::string &val, SQLTypeInfo column_type, const std::string &column_name)
HOST DEVICE SQLTypes get_type() const
Datum StringToDatum(std::string_view s, SQLTypeInfo &ti)
int64_t convert_decimal_value_to_scale(const int64_t decimal_value, const SQLTypeInfo &type_info, const SQLTypeInfo &new_type_info)
static constexpr size_t MAX_STRLEN
SQLTypeInfo get_elem_type() const