pub struct SqlParserOptions {
    pub parse_float_as_decimal: bool,
    pub enable_ident_normalization: bool,
    pub enable_options_value_normalization: bool,
    pub dialect: String,
    pub support_varchar_with_length: bool,
    pub map_string_types_to_utf8view: bool,
    pub collect_spans: bool,
    pub recursion_limit: usize,
    pub default_null_ordering: String,
}Expand description
Options related to SQL parser
See also: SessionConfig
Fields§
§parse_float_as_decimal: boolWhen set to true, SQL parser will parse float as decimal type
enable_ident_normalization: boolWhen set to true, SQL parser will normalize ident (convert ident to lowercase when not quoted)
enable_options_value_normalization: boolWhen set to true, SQL parser will normalize options value (convert value to lowercase). Note that this option is ignored and will be removed in the future. All case-insensitive values are normalized automatically.
dialect: StringConfigure the SQL dialect used by DataFusion’s parser; supported values include: Generic, MySQL, PostgreSQL, Hive, SQLite, Snowflake, Redshift, MsSQL, ClickHouse, BigQuery, Ansi, DuckDB and Databricks.
support_varchar_with_length: boolIf true, permit lengths for VARCHAR such as VARCHAR(20), but
ignore the length. If false, error if a VARCHAR with a length is
specified. The Arrow type system does not have a notion of maximum
string length and thus DataFusion can not enforce such limits.
map_string_types_to_utf8view: boolIf true, string types (VARCHAR, CHAR, Text, and String) are mapped to Utf8View during SQL planning.
If false, they are mapped to Utf8.
Default is true.
collect_spans: boolWhen set to true, the source locations relative to the original SQL
query (i.e. Span) will be collected
and recorded in the logical plan nodes.
recursion_limit: usizeSpecifies the recursion depth limit when parsing complex SQL Queries
default_null_ordering: StringSpecifies the default null ordering for query results. There are 4 options:
- nulls_max: Nulls appear last in ascending order.
- nulls_min: Nulls appear first in ascending order.
- nulls_first: Nulls always be first in any order.
- nulls_last: Nulls always be last in any order.
By default, nulls_max is used to follow Postgres’s behavior.
postgres rule: https://www.postgresql.org/docs/current/queries-order.html
Trait Implementations§
Source§impl Clone for SqlParserOptions
 
impl Clone for SqlParserOptions
Source§fn clone(&self) -> SqlParserOptions
 
fn clone(&self) -> SqlParserOptions
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl ConfigField for SqlParserOptions
 
impl ConfigField for SqlParserOptions
Source§impl Debug for SqlParserOptions
 
impl Debug for SqlParserOptions
Source§impl Default for SqlParserOptions
 
impl Default for SqlParserOptions
Source§fn default() -> SqlParserOptions
 
fn default() -> SqlParserOptions
Source§impl From<&SqlParserOptions> for ParserOptions
 
impl From<&SqlParserOptions> for ParserOptions
Source§fn from(options: &SqlParserOptions) -> ParserOptions
 
fn from(options: &SqlParserOptions) -> ParserOptions
Source§impl PartialEq for SqlParserOptions
 
impl PartialEq for SqlParserOptions
impl StructuralPartialEq for SqlParserOptions
Auto Trait Implementations§
impl Freeze for SqlParserOptions
impl RefUnwindSafe for SqlParserOptions
impl Send for SqlParserOptions
impl Sync for SqlParserOptions
impl Unpin for SqlParserOptions
impl UnwindSafe for SqlParserOptions
Blanket Implementations§
Source§impl<T> AlignerFor<1> for T
 
impl<T> AlignerFor<1> for T
Source§impl<T> AlignerFor<1024> for T
 
impl<T> AlignerFor<1024> for T
Source§type Aligner = AlignTo1024<T>
 
type Aligner = AlignTo1024<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<128> for T
 
impl<T> AlignerFor<128> for T
Source§type Aligner = AlignTo128<T>
 
type Aligner = AlignTo128<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<16> for T
 
impl<T> AlignerFor<16> for T
Source§impl<T> AlignerFor<16384> for T
 
impl<T> AlignerFor<16384> for T
Source§type Aligner = AlignTo16384<T>
 
type Aligner = AlignTo16384<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<2> for T
 
impl<T> AlignerFor<2> for T
Source§impl<T> AlignerFor<2048> for T
 
impl<T> AlignerFor<2048> for T
Source§type Aligner = AlignTo2048<T>
 
type Aligner = AlignTo2048<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<256> for T
 
impl<T> AlignerFor<256> for T
Source§type Aligner = AlignTo256<T>
 
type Aligner = AlignTo256<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<32> for T
 
impl<T> AlignerFor<32> for T
Source§impl<T> AlignerFor<32768> for T
 
impl<T> AlignerFor<32768> for T
Source§type Aligner = AlignTo32768<T>
 
type Aligner = AlignTo32768<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<4> for T
 
impl<T> AlignerFor<4> for T
Source§impl<T> AlignerFor<4096> for T
 
impl<T> AlignerFor<4096> for T
Source§type Aligner = AlignTo4096<T>
 
type Aligner = AlignTo4096<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<512> for T
 
impl<T> AlignerFor<512> for T
Source§type Aligner = AlignTo512<T>
 
type Aligner = AlignTo512<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<64> for T
 
impl<T> AlignerFor<64> for T
Source§impl<T> AlignerFor<8> for T
 
impl<T> AlignerFor<8> for T
Source§impl<T> AlignerFor<8192> for T
 
impl<T> AlignerFor<8192> for T
Source§type Aligner = AlignTo8192<T>
 
type Aligner = AlignTo8192<T>
AlignTo* type which aligns Self to ALIGNMENT.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
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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>
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>
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 moreSource§impl<T> PolicyExt for Twhere
    T: ?Sized,
 
impl<T> PolicyExt for Twhere
    T: ?Sized,
Source§impl<'a, T> RCowCompatibleRef<'a> for Twhere
    T: Clone + 'a,
 
impl<'a, T> RCowCompatibleRef<'a> for Twhere
    T: Clone + 'a,
Source§fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC
 
fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC
Source§fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T
 
fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T
Source§impl<S> ROExtAcc for S
 
impl<S> ROExtAcc for S
Source§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
 
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
offset. Read moreSource§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
 
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
offset. Read moreSource§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
 
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
offset. Read moreSource§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
 
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
offset. Read moreSource§impl<S> ROExtOps<Aligned> for S
 
impl<S> ROExtOps<Aligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
Source§impl<S> ROExtOps<Unaligned> for S
 
impl<S> ROExtOps<Unaligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
Source§impl<T> SelfOps for Twhere
    T: ?Sized,
 
impl<T> SelfOps for Twhere
    T: ?Sized,
Source§fn piped<F, U>(self, f: F) -> U
 
fn piped<F, U>(self, f: F) -> U
Source§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
 
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read moreSource§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
 
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
piped, except that the function takes &mut Self.
Useful for functions that take &mut Self instead of Self.Source§fn mutated<F>(self, f: F) -> Self
 
fn mutated<F>(self, f: F) -> Self
Source§fn observe<F>(self, f: F) -> Self
 
fn observe<F>(self, f: F) -> Self
Source§fn as_ref_<T>(&self) -> &T
 
fn as_ref_<T>(&self) -> &T
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read more