Skip to main content

LanceDbStore

Struct LanceDbStore 

Source
pub struct LanceDbStore { /* private fields */ }
Expand description

Wrapper around LanceDB connection for Uni storage.

This provides a unified interface for all table operations, replacing direct Lance Dataset usage.

Implementations§

Source§

impl LanceDbStore

Source

pub async fn connect(uri: &str) -> Result<Self>

Connect to a LanceDB database at the given URI.

Supported URIs:

  • /path/to/database - local filesystem
  • s3://bucket/path - AWS S3
  • gs://bucket/path - Google Cloud Storage
Source

pub async fn connect_with_storage_options( uri: &str, storage_options: Option<HashMap<String, String>>, ) -> Result<Self>

Connect to a LanceDB database with explicit storage options.

Source

pub fn base_uri(&self) -> &str

Get the base URI for this store.

Source

pub async fn table_names(&self) -> Result<Vec<String>>

List all table names in the database.

Source

pub async fn table_exists(&self, name: &str) -> Result<bool>

Check if a table exists.

Source

pub async fn open_table(&self, name: &str) -> Result<Table>

Open an existing table.

Source

pub async fn create_table( &self, name: &str, batches: Vec<RecordBatch>, ) -> Result<Table>

Create a new table with initial data.

If the table already exists, this will fail.

Source

pub async fn create_empty_table( &self, name: &str, schema: Arc<ArrowSchema>, ) -> Result<Table>

Create a new empty table with a schema.

Source

pub async fn open_or_create_table( &self, name: &str, schema: Arc<ArrowSchema>, ) -> Result<Table>

Open a table, creating it if it doesn’t exist.

Source

pub async fn drop_table(&self, name: &str) -> Result<()>

Drop a table by name.

Source

pub async fn drop_all_tables(&self) -> Result<()>

Drop all tables in the database.

Source

pub async fn append_to_table( &self, table: &Table, batches: Vec<RecordBatch>, ) -> Result<()>

Append data to an existing table.

Source

pub fn main_vertex_table_name() -> &'static str

Get the table name for the main vertices table.

The main vertices table contains all vertices regardless of label, enabling fast ID-based lookups without knowing the label.

Source

pub fn main_edge_table_name() -> &'static str

Get the table name for the main edges table.

The main edges table contains all edges regardless of type, enabling fast ID-based lookups without knowing the edge type.

Source

pub async fn open_main_vertex_table(&self) -> Result<Table>

Open the main vertices table.

§Errors

Returns an error if the table does not exist.

Source

pub async fn open_main_edge_table(&self) -> Result<Table>

Open the main edges table.

§Errors

Returns an error if the table does not exist.

Source

pub async fn main_vertex_table_exists(&self) -> Result<bool>

Check if the main vertices table exists.

Source

pub async fn main_edge_table_exists(&self) -> Result<bool>

Check if the main edges table exists.

Source

pub fn vertex_table_name(label: &str) -> String

Get the table name for a vertex label.

Source

pub async fn open_or_create_vertex_table( &self, label: &str, schema: Arc<ArrowSchema>, ) -> Result<Table>

Open or create a vertex table for a label.

Source

pub async fn open_vertex_table(&self, label: &str) -> Result<Table>

Open a vertex table for a label.

Source

pub async fn vertex_table_exists(&self, label: &str) -> Result<bool>

Check if a vertex table exists for a label.

Source

pub fn delta_table_name(edge_type: &str, direction: &str) -> String

Get the table name for edge deltas.

Source

pub async fn open_or_create_delta_table( &self, edge_type: &str, direction: &str, schema: Arc<ArrowSchema>, ) -> Result<Table>

Open or create a delta table.

Source

pub async fn open_delta_table( &self, edge_type: &str, direction: &str, ) -> Result<Table>

Open a delta table.

Source

pub fn adjacency_table_name(edge_type: &str, direction: &str) -> String

Get the table name for adjacency data.

Source

pub async fn open_or_create_adjacency_table( &self, edge_type: &str, direction: &str, schema: Arc<ArrowSchema>, ) -> Result<Table>

Open or create an adjacency table.

Source

pub async fn open_adjacency_table( &self, edge_type: &str, direction: &str, ) -> Result<Table>

Open an adjacency table.

Source

pub async fn get_table_version(&self, table_name: &str) -> Result<Option<u64>>

Get the current version of a table.

Returns None if the table does not exist.

§Errors

Returns an error if the table exists but version query fails.

Source

pub async fn rollback_table( &self, table_name: &str, target_version: u64, ) -> Result<()>

Roll back a table to a specific version.

This uses LanceDB’s checkout and restore APIs to create a new version that matches the state at target_version.

§Errors

Returns an error if the table cannot be opened or rollback fails.

Source

pub async fn replace_table_atomic( &self, name: &str, batches: Vec<RecordBatch>, schema: Arc<ArrowSchema>, ) -> Result<Table>

Replace a table’s contents atomically using Lance’s overwrite mode.

When the table already exists, this uses add().mode(Overwrite) to create a new dataset version without dropping the table. This is critical for concurrency safety: the old data files remain on disk (referenced by older versions) until Prune runs, so concurrent readers can finish without hitting “file not found” errors.

When the table does not exist, it creates a new table normally.

§Arguments
  • name - The table name to replace
  • batches - The new data (can be empty)
  • schema - The Arrow schema for the table
§Errors

Returns an error if table operations fail.

Source

pub async fn recover_staging(&self, name: &str) -> Result<()>

Recover a table from its staging table if needed.

This method handles crash recovery scenarios:

  • If {name}_staging exists AND {name} exists → drop staging (leftover)
  • If {name}_staging exists AND {name} missing → restore main from staging

Call this on startup for all known table patterns to recover from crashes.

§Arguments
  • name - The table name to recover
§Errors

Returns an error if recovery operations fail.

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> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. 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<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

Source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
Source§

impl<T> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T> MaybeSend for T
where T: Send,

Source§

impl<T> MaybeSend for T
where T: Send,

Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

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

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> PluginState for T
where T: Send + Sync + 'static,

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> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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