s that makes it easy to define a schema.
Basic Usage
The schema builder provides methods for each field type:noTokenize() and noStem() are used for in the section below.
Nested Objects
The schema builder supports nested object structures:Where to use the Schema
We need the schema when creating or querying an index:Tokenization & Stemming
When you store text in a search index, it goes through two transformations: Tokenization and Stemming. By default, text fields are both tokenized and stemmed. Understanding these helps you configure fields correctly.Tokenization
Tokenization splits text into individual searchable words (tokens) by breaking on spaces and punctuation.| Original Text | Tokens |
|---|---|
"hello world" | ["hello", "world"] |
"user@example.com" | ["user", "example", "com"] |
"SKU-12345-BLK" | ["SKU", "12345", "BLK"] |
.noTokenize():
- Email addresses (
user@example.com) - URLs (
https://example.com/page) - Product codes and SKUs (
SKU-12345-BLK) - UUIDs (
550e8400-e29b-41d4-a716-446655440000) - Category slugs (
electronics/phones/android)
Stemming
Stemming reduces words to their root form so different variations match the same search.| Word | Stemmed Form |
|---|---|
"running", "runs", "runner" | "run" |
"studies", "studying", "studied" | "studi" |
"experiments", "experimenting" | "experi" |
.noStem():
- Brand names (
Nikeshouldn’t matchNik) - Proper nouns and names (
Johnsonshouldn’t becomeJohn) - Technical terms (
Reactshouldn’t matchReac) - When using regex patterns (stemmed text won’t match your expected patterns)
Aliased Fields
Aliased fields allow you to index the same document field multiple times with different settings, or to create shorter names for complex nested paths. Use theFROM keyword to specify which document field the alias points to.
- TypeScript
- Redis CLI
- Same field with different settings: Index a text field both with and without stemming. Use the stemmed version for general searches and the non-stemmed version for exact matching or regex queries.
- Shorter query paths: Create concise aliases for deeply nested fields like
metadata.author.displayNameto simplify queries.
When using aliased fields:
- Use the alias name in queries and highlighting (e.g.,
descriptionExact,authorName) - Use the actual field name when selecting fields to return (e.g.,
description,metadata.author.displayName)
Non-Indexed Fields
Documents don’t need to match the schema exactly:- Extra fields: Fields in your document that aren’t defined in the schema are simply ignored. They won’t be indexed or searchable.
- Missing fields: If a document is missing a field defined in the schema, that document won’t appear in search results that filter on the missing field.
Schema Examples
E-commerce product schema- TypeScript
- Redis CLI
- TypeScript
- Redis CLI