Skip to main content

OrderByClause

Struct OrderByClause 

Source
pub struct OrderByClause {
    pub field: String,
    pub field_source: FieldSource,
    pub direction: SortOrder,
    pub collation: Option<String>,
    pub nulls_handling: Option<NullsHandling>,
}
Expand description

Represents a complete ORDER BY clause

Supports:

  • Both JSONB fields and direct columns
  • PostgreSQL collations
  • NULLS FIRST/LAST handling
  • Mixed multi-field ordering

§Examples

use fraiseql_wire::operators::{OrderByClause, FieldSource, SortOrder, NullsHandling};

// Order by JSONB field with collation
let _ = OrderByClause {
    field: "name".to_string(),
    field_source: FieldSource::JsonbPayload,
    direction: SortOrder::Asc,
    collation: Some("en-US".to_string()),
    nulls_handling: None,
};

// Order by direct column with NULLS LAST
let _ = OrderByClause {
    field: "created_at".to_string(),
    field_source: FieldSource::DirectColumn,
    direction: SortOrder::Desc,
    collation: None,
    nulls_handling: Some(NullsHandling::Last),
};

Fields§

§field: String

Field name (validated separately based on field_source)

§field_source: FieldSource

Where the field comes from

§direction: SortOrder

Sort direction

§collation: Option<String>

Optional collation name (e.g., “en-US”, “C”, “de_DE.UTF-8”)

When specified, generates: field COLLATE "collation_name"

§nulls_handling: Option<NullsHandling>

Optional NULLS handling

Implementations§

Source§

impl OrderByClause

Source

pub fn jsonb_field(field: impl Into<String>, direction: SortOrder) -> Self

Create a new ORDER BY clause for a JSONB field

Source

pub fn direct_column(field: impl Into<String>, direction: SortOrder) -> Self

Create a new ORDER BY clause for a direct column

Source

pub fn with_collation(self, collation: impl Into<String>) -> Self

Add collation to this clause

Source

pub const fn with_nulls(self, handling: NullsHandling) -> Self

Add NULLS handling to this clause

Source

pub fn validate(&self) -> Result<(), String>

Validate field name to prevent SQL injection

§Errors

Returns an error string if the field name is empty, contains invalid characters, or the collation name (if set) contains invalid characters.

Source

pub fn to_sql(&self) -> Result<String, String>

Generate SQL for this clause

§Examples
  • JSONB with collation: (data->'name') COLLATE "en-US" ASC
  • Direct column: created_at DESC
  • With NULLS: status ASC NULLS LAST
§Errors

Returns an error string if the clause fails validation (see Self::validate).

Trait Implementations§

Source§

impl Clone for OrderByClause

Source§

fn clone(&self) -> OrderByClause

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for OrderByClause

Source§

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

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

impl Display for OrderByClause

Source§

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

Formats the value using the given formatter. Read more

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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§

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>,

Source§

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>,

Source§

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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more