Struct tantivy::schema::SchemaBuilder

source ·
pub struct SchemaBuilder { /* private fields */ }
Expand description

Tantivy has a very strict schema. You need to specify in advance whether a field is indexed or not, stored or not, and RAM-based or not.

This is done by creating a schema object, and setting up the fields one by one. It is for the moment impossible to remove fields.

§Examples

use tantivy::schema::*;

let mut schema_builder = Schema::builder();
let id_field = schema_builder.add_text_field("id", STRING);
let title_field = schema_builder.add_text_field("title", TEXT);
let body_field = schema_builder.add_text_field("body", TEXT);
let schema = schema_builder.build();

Implementations§

source§

impl SchemaBuilder

source

pub fn new() -> SchemaBuilder

Create a new SchemaBuilder

source

pub fn add_u64_field<T: Into<NumericOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new u64 field. Returns the associated field handle

§Panics

Panics when field already exists.

source

pub fn add_i64_field<T: Into<NumericOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new i64 field. Returns the associated field handle

§Panics

Panics when field already exists.

source

pub fn add_f64_field<T: Into<NumericOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new f64 field. Returns the associated field handle

§Panics

Panics when field already exists.

source

pub fn add_bool_field<T: Into<NumericOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new bool field. Returns the associated field handle

§Panics

Panics when field already exists.

source

pub fn add_date_field<T: Into<DateOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new date field. Returns the associated field handle Internally, Tantivy simply stores dates as i64 UTC timestamps, while the user supplies DateTime values for convenience.

§Panics

Panics when field already exists.

source

pub fn add_ip_addr_field<T: Into<IpAddrOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a ip field. Returns the associated field handle.

§Panics

Panics when field already exists.

source

pub fn add_text_field<T: Into<TextOptions>>( &mut self, field_name_str: &str, field_options: T ) -> Field

Adds a new text field. Returns the associated field handle

§Panics

Panics when field already exists.

source

pub fn add_facet_field( &mut self, field_name: &str, facet_options: impl Into<FacetOptions> ) -> Field

Adds a facet field to the schema.

source

pub fn add_bytes_field<T: Into<BytesOptions>>( &mut self, field_name: &str, field_options: T ) -> Field

Adds a fast bytes field to the schema.

Bytes field are not searchable and are only used as fast field, to associate any kind of payload to a document.

For instance, learning-to-rank often requires to access some document features at scoring time. These can be serializing and stored as a bytes field to get access rapidly when scoring each document.

source

pub fn add_json_field<T: Into<JsonObjectOptions>>( &mut self, field_name: &str, field_options: T ) -> Field

Adds a json object field to the schema.

source

pub fn add_field(&mut self, field_entry: FieldEntry) -> Field

Adds a field entry to the schema in build.

source

pub fn build(self) -> Schema

Finalize the creation of a Schema This will consume your SchemaBuilder

Trait Implementations§

source§

impl Debug for SchemaBuilder

source§

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

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

impl Default for SchemaBuilder

source§

fn default() -> SchemaBuilder

Returns the “default value” for a type. 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> Downcast for T
where T: Any,

source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

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, 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> Fruit for T
where T: Send + Downcast,