ConstraintService

Struct ConstraintService 

Source
pub struct ConstraintService<P>
where P: Pager<Blob = EntryHandle> + Send + Sync,
{ /* private fields */ }
Expand description

High-level constraint service API intended for runtime consumers.

Implementations§

Source§

impl<P> ConstraintService<P>
where P: Pager<Blob = EntryHandle> + Send + Sync,

Source

pub fn new( metadata: Arc<MetadataManager<P>>, catalog: Arc<TableCatalog>, ) -> Self

Create a new constraint validation service.

Source

pub fn validate_insert_foreign_keys<F>( &self, referencing_table_id: TableId, schema_field_ids: &[FieldId], column_order: &[usize], rows: &[Vec<PlanValue>], fetch_parent_rows: F, ) -> LlkvResult<()>

Validate that incoming INSERT rows satisfy the table’s foreign key constraints.

Source

pub fn validate_insert_constraints<FSingle, FMulti>( &self, schema_field_ids: &[FieldId], column_constraints: &[InsertColumnConstraint], unique_columns: &[InsertUniqueColumn], multi_column_uniques: &[InsertMultiColumnUnique], primary_key: Option<&InsertMultiColumnUnique>, column_order: &[usize], rows: &[Vec<PlanValue>], fetch_column_values: FSingle, fetch_multi_column_rows: FMulti, ) -> LlkvResult<()>
where FSingle: FnMut(FieldId) -> LlkvResult<Vec<PlanValue>>, FMulti: FnMut(&[FieldId]) -> LlkvResult<Vec<Vec<PlanValue>>>,

Validate INSERT rows against all table constraints including primary keys, unique constraints, and CHECK expressions. This is a comprehensive validation that combines uniqueness checks (both single-column and multi-column) with row-level CHECK constraint evaluation.

Source

pub fn validate_row_level_constraints( &self, schema_field_ids: &[FieldId], column_constraints: &[InsertColumnConstraint], column_order: &[usize], rows: &[Vec<PlanValue>], ) -> LlkvResult<()>

Validate rows against CHECK constraints. This method evaluates CHECK expressions for each row, ensuring they satisfy the table’s row-level constraint rules.

Source

pub fn validate_primary_key_rows<F>( &self, schema_field_ids: &[FieldId], primary_key: &InsertMultiColumnUnique, column_order: &[usize], rows: &[Vec<PlanValue>], fetch_multi_column_rows: F, ) -> LlkvResult<()>
where F: FnMut(&[FieldId]) -> LlkvResult<Vec<Vec<PlanValue>>>,

Validate that INSERT rows satisfy the primary key constraint by checking for duplicates against both existing rows in the table and within the new batch.

Source

pub fn validate_update_primary_keys<F>( &self, schema_field_ids: &[FieldId], primary_key: &InsertMultiColumnUnique, column_order: &[usize], rows: &[Vec<PlanValue>], original_keys: &[Option<UniqueKey>], fetch_multi_column_rows: F, ) -> LlkvResult<()>
where F: FnMut(&[FieldId]) -> LlkvResult<Vec<Vec<PlanValue>>>,

Validate UPDATE operations that modify primary key columns. Ensures that updated primary key values don’t conflict with existing rows (excluding the original row being updated).

Source

pub fn validate_delete_foreign_keys<FParents, FChildren>( &self, referenced_table_id: TableId, referenced_row_ids: &[RowId], fetch_parent_rows: FParents, fetch_child_rows: FChildren, ) -> LlkvResult<()>

Validate that deleting the given rows will not violate foreign key constraints.

Source

pub fn validate_update_foreign_keys<FParents, FChildren>( &self, referenced_table_id: TableId, referenced_row_ids: &[RowId], updated_field_ids: &[FieldId], fetch_parent_rows: FParents, fetch_child_rows: FChildren, ) -> LlkvResult<()>

Validate that updating the given rows will not violate foreign key constraints.

This checks if any columns being updated are referenced by foreign keys, and whether the OLD values are still being referenced by child tables.

Source

pub fn referencing_foreign_keys( &self, referenced_table_id: TableId, ) -> LlkvResult<Vec<ForeignKeyView>>

Return the set of foreign keys referencing the provided table.

Trait Implementations§

Source§

impl<P> Clone for ConstraintService<P>
where P: Pager<Blob = EntryHandle> + Send + Sync + Clone,

Source§

fn clone(&self) -> ConstraintService<P>

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. 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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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.
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
Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,