pub struct ColumnTypeJson {
pub name: Option<PlSmallStr>,
pub type_: ColumnTypeJsonType,
pub nullable: Option<bool>,
pub metadata: Option<PlHashMap<String, String>>,
pub element_type: Option<ColumnTypeJsonType>,
pub contains_null: Option<bool>,
pub fields: Option<Vec<ColumnTypeJson>>,
pub key_type: Option<ColumnTypeJsonType>,
pub value_type: Option<ColumnTypeJsonType>,
pub value_contains_null: Option<bool>,
}Available on crate feature
catalog only.Expand description
Note: This struct contains all the field names for a few different possible type / field presence combinations. We use serde(default) and skip_serializing_if to get the desired serialization output.
E.g.:
{
"name": "List",
"type": {"type": "array", "elementType": "long", "containsNull": True},
"nullable": True,
"metadata": {},
}
{
"name": "Struct",
"type": {
"type": "struct",
"fields": [{"name": "x", "type": "long", "nullable": True, "metadata": {}}],
},
"nullable": True,
"metadata": {},
}
{
"name": "ListStruct",
"type": {
"type": "array",
"elementType": {
"type": "struct",
"fields": [{"name": "x", "type": "long", "nullable": True, "metadata": {}}],
},
"containsNull": True,
},
"nullable": True,
"metadata": {},
}
{
"name": "Map",
"type": {
"type": "map",
"keyType": "string",
"valueType": "string",
"valueContainsNull": True,
},
"nullable": True,
"metadata": {},
}Fields§
§name: Option<PlSmallStr>§type_: ColumnTypeJsonType§nullable: Option<bool>§metadata: Option<PlHashMap<String, String>>§element_type: Option<ColumnTypeJsonType>§contains_null: Option<bool>§fields: Option<Vec<ColumnTypeJson>>§key_type: Option<ColumnTypeJsonType>§value_type: Option<ColumnTypeJsonType>§value_contains_null: Option<bool>Trait Implementations§
Source§impl Debug for ColumnTypeJson
impl Debug for ColumnTypeJson
Source§impl Default for ColumnTypeJson
impl Default for ColumnTypeJson
Source§fn default() -> ColumnTypeJson
fn default() -> ColumnTypeJson
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for ColumnTypeJson
impl<'de> Deserialize<'de> for ColumnTypeJson
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for ColumnTypeJson
impl RefUnwindSafe for ColumnTypeJson
impl Send for ColumnTypeJson
impl Sync for ColumnTypeJson
impl Unpin for ColumnTypeJson
impl UnsafeUnpin for ColumnTypeJson
impl UnwindSafe for ColumnTypeJson
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more