Enum sqlparser::ast::BinaryOperator

source ·
pub enum BinaryOperator {
Show 49 variants Plus, Minus, Multiply, Divide, Modulo, StringConcat, Gt, Lt, GtEq, LtEq, Spaceship, Eq, NotEq, And, Or, Xor, BitwiseOr, BitwiseAnd, BitwiseXor, DuckIntegerDivide, MyIntegerDivide, Custom(String), PGBitwiseXor, PGBitwiseShiftLeft, PGBitwiseShiftRight, PGExp, PGOverlap, PGRegexMatch, PGRegexIMatch, PGRegexNotMatch, PGRegexNotIMatch, PGLikeMatch, PGILikeMatch, PGNotLikeMatch, PGNotILikeMatch, PGStartsWith, Arrow, LongArrow, HashArrow, HashLongArrow, AtAt, AtArrow, ArrowAt, HashMinus, AtQuestion, Question, QuestionAnd, QuestionPipe, PGCustomBinaryOperator(Vec<String>),
}
Expand description

Binary operators

Variants§

§

Plus

Plus, e.g. a + b

§

Minus

Minus, e.g. a - b

§

Multiply

Multiply, e.g. a * b

§

Divide

Divide, e.g. a / b

§

Modulo

Modulo, e.g. a % b

§

StringConcat

String/Array Concat operator, e.g. a || b

§

Gt

Greater than, e.g. a > b

§

Lt

Less than, e.g. a < b

§

GtEq

Greater equal, e.g. a >= b

§

LtEq

Less equal, e.g. a <= b

§

Spaceship

Spaceship, e.g. a <=> b

§

Eq

Equal, e.g. a = b

§

NotEq

Not equal, e.g. a <> b

§

And

And, e.g. a AND b

§

Or

Or, e.g. a OR b

§

Xor

XOR, e.g. a XOR b

§

BitwiseOr

Bitwise or, e.g. a | b

§

BitwiseAnd

Bitwise and, e.g. a & b

§

BitwiseXor

Bitwise XOR, e.g. a ^ b

§

DuckIntegerDivide

Integer division operator // in DuckDB

§

MyIntegerDivide

MySQL DIV integer division

§

Custom(String)

Support for custom operators (built by parsers outside this crate)

§

PGBitwiseXor

Bitwise XOR, e.g. a # b (PostgreSQL-specific)

§

PGBitwiseShiftLeft

Bitwise shift left, e.g. a << b (PostgreSQL-specific)

§

PGBitwiseShiftRight

Bitwise shift right, e.g. a >> b (PostgreSQL-specific)

§

PGExp

Exponent, e.g. a ^ b (PostgreSQL-specific)

§

PGOverlap

Overlap operator, e.g. a && b (PostgreSQL-specific)

§

PGRegexMatch

String matches regular expression (case sensitively), e.g. a ~ b (PostgreSQL-specific)

§

PGRegexIMatch

String matches regular expression (case insensitively), e.g. a ~* b (PostgreSQL-specific)

§

PGRegexNotMatch

String does not match regular expression (case sensitively), e.g. a !~ b (PostgreSQL-specific)

§

PGRegexNotIMatch

String does not match regular expression (case insensitively), e.g. a !~* b (PostgreSQL-specific)

§

PGLikeMatch

String matches pattern (case sensitively), e.g. a ~~ b (PostgreSQL-specific)

§

PGILikeMatch

String matches pattern (case insensitively), e.g. a ~~* b (PostgreSQL-specific)

§

PGNotLikeMatch

String does not match pattern (case sensitively), e.g. a !~~ b (PostgreSQL-specific)

§

PGNotILikeMatch

String does not match pattern (case insensitively), e.g. a !~~* b (PostgreSQL-specific)

§

PGStartsWith

String “starts with”, eg: a ^@ b (PostgreSQL-specific)

§

Arrow

The -> operator.

On PostgreSQL, this operator extracts a JSON object field or array element, for example '{"a":"b"}'::json -> 'a' or [1, 2, 3]'::json -> 2.

See https://www.postgresql.org/docs/current/functions-json.html.

§

LongArrow

The ->> operator.

On PostgreSQL, this operator that extracts a JSON object field or JSON array element and converts it to text, for example '{"a":"b"}'::json ->> 'a' or [1, 2, 3]'::json ->> 2.

See https://www.postgresql.org/docs/current/functions-json.html.

§

HashArrow

The #> operator.

On PostgreSQL, this operator extracts a JSON sub-object at the specified path, for example:

'{"a": {"b": ["foo","bar"]}}'::json #> '{a,b,1}'

See https://www.postgresql.org/docs/current/functions-json.html.

§

HashLongArrow

The #>> operator.

A PostgreSQL-specific operator that extracts JSON sub-object at the specified path, for example

'{"a": {"b": ["foo","bar"]}}'::json #>> '{a,b,1}'

See https://www.postgresql.org/docs/current/functions-json.html.

§

AtAt

The @@ operator.

On PostgreSQL, this is used for JSON and text searches.

See https://www.postgresql.org/docs/current/functions-json.html. See https://www.postgresql.org/docs/current/functions-textsearch.html.

§

AtArrow

The @> operator.

On PostgreSQL, this is used for JSON and text searches.

See https://www.postgresql.org/docs/current/functions-json.html. See https://www.postgresql.org/docs/current/functions-textsearch.html.

§

ArrowAt

The <@ operator.

On PostgreSQL, this is used for JSON and text searches.

See https://www.postgresql.org/docs/current/functions-json.html. See https://www.postgresql.org/docs/current/functions-textsearch.html.

§

HashMinus

The #- operator.

On PostgreSQL, this operator is used to delete a field or array element at a specified path.

See https://www.postgresql.org/docs/current/functions-json.html.

§

AtQuestion

The @? operator.

On PostgreSQL, this operator is used to check the given JSON path returns an item for the JSON value.

See https://www.postgresql.org/docs/current/functions-json.html.

§

Question

The ? operator.

On PostgreSQL, this operator is used to check whether a string exists as a top-level key within the JSON value

See https://www.postgresql.org/docs/current/functions-json.html.

§

QuestionAnd

The ?& operator.

On PostgreSQL, this operator is used to check whether all of the the indicated array members exist as top-level keys.

See https://www.postgresql.org/docs/current/functions-json.html.

§

QuestionPipe

The ?| operator.

On PostgreSQL, this operator is used to check whether any of the the indicated array members exist as top-level keys.

See https://www.postgresql.org/docs/current/functions-json.html.

§

PGCustomBinaryOperator(Vec<String>)

PostgreSQL-specific custom operator.

See CREATE OPERATOR for more information.

Trait Implementations§

source§

impl Clone for BinaryOperator

source§

fn clone(&self) -> BinaryOperator

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for BinaryOperator

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for BinaryOperator

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for BinaryOperator

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Hash for BinaryOperator

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Ord for BinaryOperator

source§

fn cmp(&self, other: &BinaryOperator) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for BinaryOperator

source§

fn eq(&self, other: &BinaryOperator) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for BinaryOperator

source§

fn partial_cmp(&self, other: &BinaryOperator) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Serialize for BinaryOperator

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Visit for BinaryOperator

source§

fn visit<V: Visitor>(&self, visitor: &mut V) -> ControlFlow<V::Break>

source§

impl VisitMut for BinaryOperator

source§

fn visit<V: VisitorMut>(&mut self, visitor: &mut V) -> ControlFlow<V::Break>

source§

impl Eq for BinaryOperator

source§

impl StructuralPartialEq for BinaryOperator

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,