All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.redis.datasource.search.SearchCommands Maven / Gradle / Ivy

There is a newer version: 3.18.0.CR1
Show newest version
package io.quarkus.redis.datasource.search;

import java.util.List;
import java.util.Set;

import io.quarkus.redis.datasource.RedisCommands;
import io.smallrye.common.annotation.Experimental;

/**
 * Allows executing commands from the {@code search} group (requires the Redis Search module from Redis stack).
 * See the search command list for further information about these
 * commands.
 * 

* allows querying, secondary indexing, and full-text * search for Redis. *

* * @param the type of the key */ @Experimental("The commands from the search group are experimental") public interface SearchCommands extends RedisCommands { /** * Execute the command FT._LIST. * Summary: Returns a list of all existing indexes. * Group: search *

* This is a temporary command. * * @return A uni emitting the list of the keys */ List ft_list(); /** * Execute the command FT.AGGREGATE. * Summary: Run a search query on an index, and perform aggregate transformations on the results, extracting * statistics from them * Group: search * * @param indexName the index against which the query is executed. * @param query the filtering query that retrieves the documents. It follows the exact same syntax as the search * query, including filters, unions, not, optional, and so on. * @param args the extra parameters * @return A uni emitting the response to the aggregate */ AggregationResponse ftAggregate(String indexName, String query, AggregateArgs args); /** * Execute the command FT.AGGREGATE. * Summary: Run a search query on an index, and perform aggregate transformations on the results, extracting * statistics from them * Group: search * * @param indexName the index against which the query is executed. * @param query the filtering query that retrieves the documents. It follows the exact same syntax as the search * query, including filters, unions, not, optional, and so on. * @return A uni emitting the response to the query */ AggregationResponse ftAggregate(String indexName, String query); /** * Execute the command FT.ALIASADD. * Summary: Add an alias to an index * Group: search * * @param alias the alias to be added to an index. * @param index the index */ void ftAliasAdd(String alias, String index); /** * Execute the command FT.ALIASDEL. * Summary: Remove an alias from an index * Group: search * * @param alias the alias to be removed */ void ftAliasDel(String alias); /** * Execute the command FT.ALIASUPDATE. * Summary: Add an alias to an index. If the alias is already associated with another index, FT.ALIASUPDATE removes * the alias association with the previous index. * Group: search * * @param alias the alias to be added to an index. * @param index the index */ void ftAliasUpdate(String alias, String index); /** * Execute the command FT.ALTER. * Summary: Add a new attribute to the index. Adding an attribute to the index causes any future document updates * to use the new attribute when indexing and reindexing existing documents. * Group: search * * @param index the index * @param field the indexed field to add * @param skipInitialScan whether to skip the initial scan, if set to {@code true}, does not scan and index. */ void ftAlter(String index, IndexedField field, boolean skipInitialScan); /** * Execute the command FT.ALTER. * Summary: Add a new attribute to the index. Adding an attribute to the index causes any future document updates * to use the new attribute when indexing and reindexing existing documents. * Group: search * * @param index the index * @param field the indexed field to add */ default void ftAlter(String index, IndexedField field) { ftAlter(index, field, false); } /** * Execute the command FT.CREATE. * Summary: Create an index with the given specification. * Group: search * * @param index the index * @param args the creation arguments. */ void ftCreate(String index, CreateArgs args); /** * Execute the command FT.CURSOR DEL. * Summary: Delete a cursor * Group: search * * @param index the index * @param cursor the cursor id */ void ftCursorDel(String index, long cursor); /** * Execute the command FT.CURSOR READ. * Summary: Read next results from an existing cursor * Group: search * * @param index the index * @param cursor the cursor id * @return A uni emitting the aggregate response */ AggregationResponse ftCursorRead(String index, long cursor); /** * Execute the command FT.CURSOR READ. * Summary: Read next results from an existing cursor * Group: search * * @param index the index * @param cursor the cursor id * @param count the number of results to read * @return A uni emitting the aggregate response. This parameter overrides {@code COUNT} specified in * {@code FT.AGGREGATE}. */ AggregationResponse ftCursorRead(String index, long cursor, int count); /** * Execute the command FT.DROPINDEX. * Summary: Delete an index * Group: search * * @param index the index */ void ftDropIndex(String index); /** * Execute the command FT.DROPINDEX. * Summary: Delete an index * Group: search * * @param index the index * @param dd drop operation that, if set, deletes the actual document hashes. */ void ftDropIndex(String index, boolean dd); /** * Execute the command FT.DICTADD. * Summary: Add terms to a dictionary * Group: search * * @param dict the dictionary name * @param words the terms to add to the dictionary */ void ftDictAdd(String dict, String... words); /** * Execute the command FT.DICTDEL. * Summary: Remove terms from a dictionary * Group: search * * @param dict the dictionary name * @param words the terms to remove to the dictionary */ void ftDictDel(String dict, String... words); /** * Execute the command FT.DICTDUMP. * Summary: Dump all terms in the given dictionary * Group: search * * @param dict the dictionary name * @return A uni emitting the list of words (terms) included in the dictionary */ List ftDictDump(String dict); /** * Execute the command FT.SEARCH. * Summary: Search the index with a textual query, returning either documents or just ids * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @param args the extra parameters * @return A uni emitting the {@link SearchQueryResponse} */ SearchQueryResponse ftSearch(String index, String query, QueryArgs args); /** * Execute the command FT.SEARCH. * Summary: Search the index with a textual query, returning either documents or just ids * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @return A uni emitting the {@link SearchQueryResponse} */ SearchQueryResponse ftSearch(String index, String query); /** * Execute the command FT.SPELLCHECK. * Summary: Perform spelling correction on a query, returning suggestions for misspelled terms * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @return A uni emitting the {@link SpellCheckResponse} */ SpellCheckResponse ftSpellCheck(String index, String query); /** * Execute the command FT.SPELLCHECK. * Summary: Perform spelling correction on a query, returning suggestions for misspelled terms * Group: search * * @param index the index name. You must first create the index using {@code FT.CREATE}. * @param query the text query to search. * @param args the extra parameters * @return A uni emitting the {@link SpellCheckResponse} */ SpellCheckResponse ftSpellCheck(String index, String query, SpellCheckArgs args); /** * Execute the command FT.SYNDUMP. * Summary: Dump the contents of a synonym group * Group: search * * @param index the index name. * @return A uni emitting the {@link SynDumpResponse} */ SynDumpResponse ftSynDump(String index); /** * Execute the command FT.SYNUPDATE. * Summary: Update a synonym group * Group: search * * @param index the index name. * @param groupId the synonym group * @param words the synonyms */ void ftSynUpdate(String index, String groupId, String... words); /** * Execute the command FT.SYNUPDATE. * Summary: Update a synonym group * Group: search * * @param index the index name. * @param groupId the synonym group * @param skipInitialScan if set to {@code true}, does not scan and index, and only documents that are indexed * after the update are affected. * @param words the synonyms */ void ftSynUpdate(String index, String groupId, boolean skipInitialScan, String... words); /** * Execute the command FT.TAGVALS. * Summary: return a distinct set of values indexed in a Tag field * Group: search * * @param index the index name. * @param field the name of a tag file defined in the schema. * @return A uni emitting the set of values indexed in a Tag field */ Set ftTagVals(String index, String field); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy