Skip to main content

LiteralSql

Struct LiteralSql 

Source
pub struct LiteralSql(/* private fields */);
Expand description

A SQL fragment emitted verbatim into the query text, not bound as a parameter (e.g. literal key names in json_build_object).

Because the contained text bypasses parameter binding, it must never carry untrusted user input. This newtype makes that contract explicit: a value can only be created through LiteralSql::from_static (compile-time safe) or LiteralSql::trusted (a deliberately-named, greppable assertion that the caller vetted the string). The inner String is private, so an Expr::Literal can never be built directly from a bare runtime string.

Implementations§

Source§

impl LiteralSql

Source

pub fn from_static(text: &'static str) -> Self

Build from a compile-time string. Always safe: a &'static str baked into the binary can never be untrusted user input.

Source

pub fn trusted(text: impl Into<String>) -> Self

Build from a runtime string the caller asserts is trusted (e.g. a schema column name), never raw user input. Prefer Self::from_static when the value is known at compile time.

Source

pub fn as_str(&self) -> &str

The underlying SQL text.

Trait Implementations§

Source§

impl Clone for LiteralSql

Source§

fn clone(&self) -> LiteralSql

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 LiteralSql

Source§

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

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

impl PartialEq for LiteralSql

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for LiteralSql

Source§

impl StructuralPartialEq for LiteralSql

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

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