Enum aws_sdk_quicksight::model::ColumnDataType
source · #[non_exhaustive]
pub enum ColumnDataType {
Datetime,
Decimal,
Integer,
String,
Unknown(UnknownVariantValue),
}Expand description
When writing a match expression against ColumnDataType, it is important to ensure
your code is forward-compatible. That is, if a match arm handles a case for a
feature that is supported by the service but has not been represented as an enum
variant in a current version of SDK, your code should continue to work when you
upgrade SDK to a future version in which the enum does include a variant for that
feature.
Here is an example of how you can make a match expression forward-compatible:
# let columndatatype = unimplemented!();
match columndatatype {
ColumnDataType::Datetime => { /* ... */ },
ColumnDataType::Decimal => { /* ... */ },
ColumnDataType::Integer => { /* ... */ },
ColumnDataType::String => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when columndatatype represents
NewFeature, the execution path will lead to the second last match arm,
even though the enum does not contain a variant ColumnDataType::NewFeature
in the current version of SDK. The reason is that the variable other,
created by the @ operator, is bound to
ColumnDataType::Unknown(UnknownVariantValue("NewFeature".to_owned()))
and calling as_str on it yields "NewFeature".
This match expression is forward-compatible when executed with a newer
version of SDK where the variant ColumnDataType::NewFeature is defined.
Specifically, when columndatatype represents NewFeature,
the execution path will hit the second last match arm as before by virtue of
calling as_str on ColumnDataType::NewFeature also yielding "NewFeature".
Explicitly matching on the Unknown variant should
be avoided for two reasons:
- The inner data
UnknownVariantValueis opaque, and no further information can be extracted. - It might inadvertently shadow other intended match arms.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Datetime
Decimal
Integer
String
Unknown(UnknownVariantValue)
Unknown contains new variants that have been added since this code was generated.
Implementations§
source§impl ColumnDataType
impl ColumnDataType
sourcepub fn as_str(&self) -> &str
pub fn as_str(&self) -> &str
Returns the &str value of the enum member.
Examples found in repository?
More examples
3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588
pub fn serialize_structure_crate_model_cast_column_type_operation(
object: &mut aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::model::CastColumnTypeOperation,
) -> Result<(), aws_smithy_http::operation::error::SerializationError> {
if let Some(var_681) = &input.column_name {
object.key("ColumnName").string(var_681.as_str());
}
if let Some(var_682) = &input.new_column_type {
object.key("NewColumnType").string(var_682.as_str());
}
if let Some(var_683) = &input.format {
object.key("Format").string(var_683.as_str());
}
Ok(())
}Trait Implementations§
source§impl AsRef<str> for ColumnDataType
impl AsRef<str> for ColumnDataType
source§impl Clone for ColumnDataType
impl Clone for ColumnDataType
source§fn clone(&self) -> ColumnDataType
fn clone(&self) -> ColumnDataType
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for ColumnDataType
impl Debug for ColumnDataType
source§impl From<&str> for ColumnDataType
impl From<&str> for ColumnDataType
source§impl FromStr for ColumnDataType
impl FromStr for ColumnDataType
source§impl Hash for ColumnDataType
impl Hash for ColumnDataType
source§impl Ord for ColumnDataType
impl Ord for ColumnDataType
source§fn cmp(&self, other: &ColumnDataType) -> Ordering
fn cmp(&self, other: &ColumnDataType) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<ColumnDataType> for ColumnDataType
impl PartialEq<ColumnDataType> for ColumnDataType
source§fn eq(&self, other: &ColumnDataType) -> bool
fn eq(&self, other: &ColumnDataType) -> bool
source§impl PartialOrd<ColumnDataType> for ColumnDataType
impl PartialOrd<ColumnDataType> for ColumnDataType
source§fn partial_cmp(&self, other: &ColumnDataType) -> Option<Ordering>
fn partial_cmp(&self, other: &ColumnDataType) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read moreimpl Eq for ColumnDataType
impl StructuralEq for ColumnDataType
impl StructuralPartialEq for ColumnDataType
Auto Trait Implementations§
impl RefUnwindSafe for ColumnDataType
impl Send for ColumnDataType
impl Sync for ColumnDataType
impl Unpin for ColumnDataType
impl UnwindSafe for ColumnDataType
Blanket Implementations§
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.