Definition at line 523 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::kMULTILINESTRING, kMULTILINESTRING, Geospatial::GeoBase::kMULTIPOINT, kMULTIPOINT, 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().
544 validator.validate(d.bigintval);
553 validator.validate(converted_val);
560 throw std::runtime_error(
"String too long for column " + column_name +
" was " +
566 if (val.front() !=
'{' || val.back() !=
'}') {
567 throw std::runtime_error(column_name +
568 ": arrays should start and end with curly braces");
570 std::vector<std::string> elements =
split(val.substr(1, val.length() - 2),
", ");
573 size_t expected_size = column_type.
get_size() / sti.get_size();
574 size_t actual_size = elements.size();
575 if (actual_size != expected_size) {
576 throw std::runtime_error(
"Fixed length array column " + column_name +
582 for (
const auto& element : elements) {
601 throw std::runtime_error(
"Unexpected geo literal '" + val +
"' for column " +
604 if (!geo->transform(column_type)) {
605 throw std::runtime_error(
"Cannot transform SRID for literal '" + val +
606 "' for column " + column_name);
608 auto sql_type = column_type.
get_type();
609 auto geo_type = geo->getType();
621 throw std::runtime_error(
"Geo literal '" + val +
622 "' doesn't match the type "
623 "of column column " +
628 throw std::runtime_error(
"Unexpected geo literal '" + val +
"' for column " +
629 column_name +
": " + e.what());
633 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(const 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