Sintaxe de consulta Lucene na Pesquisa de IA do Azure
Ao criar consultas no Azure AI Search, você pode optar pela sintaxe completa do Lucene Query Parser para formulários de consulta especializados: curinga, pesquisa difusa, pesquisa de proximidade, expressões regulares. Grande parte da sintaxe do Lucene Query Parser é implementada intacta na Pesquisa de IA do Azure, exceto para pesquisas de intervalo, que são construídas por meio de $filter
expressões.
Para usar a sintaxe Lucene completa, defina queryType como full
e passe uma expressão de consulta padronizada para curinga, pesquisa difusa ou um dos outros formulários de consulta suportados pela sintaxe completa. Em REST, as search
expressões de consulta são fornecidas no parâmetro de uma solicitação de Documentos de Pesquisa (API REST).
O exemplo a seguir é uma solicitação de pesquisa construída usando a sintaxe completa. Este exemplo em particular mostra a pesquisa em campo e o aumento de termos. Procura hotéis onde o campo de categoria contém o termo budget
. Todos os documentos que contenham a frase "recently renovated"
são classificados mais alto como resultado do termo boost value (3).
POST /indexes/hotels-sample-index/docs/search?api-version=2024-07-01
{
"queryType": "full",
"search": "category:budget AND \"recently renovated\"^3",
"searchMode": "all"
}
Embora não seja específico para nenhum tipo de consulta, o searchMode
parâmetro é relevante neste exemplo. Sempre que os operadores estiverem na consulta, você geralmente deve definir searchMode=all
para garantir que todos os critérios sejam correspondidos.
Para obter mais exemplos, consulte Exemplos de sintaxe de consulta Lucene. Para obter detalhes sobre a solicitação de consulta e os parâmetros, incluindo searchMode, consulte Pesquisar documentos (API REST).
Os fundamentos de sintaxe a seguir se aplicam a todas as consultas que usam a sintaxe Lucene.
O posicionamento determina se um símbolo é interpretado como um operador ou apenas outro caractere em uma cadeia de caracteres.
Por exemplo, na sintaxe completa de Lucene, o til (~
) é usado tanto para pesquisa difusa quanto para pesquisa de proximidade. Quando colocado após uma frase citada, ~
invoca a pesquisa de proximidade. Quando colocado no final de um termo, ~
invoca a pesquisa difusa.
Dentro de um termo, como business~analyst
, o personagem não é avaliado como um operador. Neste caso, assumindo que a consulta é uma consulta de termo ou frase, a pesquisa de texto completo com análise lexical retira o ~
termo e divide o termo business~analyst
em dois: business
OU analyst
.
O exemplo acima é o til (~
), mas o mesmo princípio se aplica a todos os operadores.
Para usar qualquer um dos operadores de pesquisa como parte do texto de pesquisa, escape do caractere prefixando-o com uma única barra invertida (\
). Por exemplo, para uma pesquisa curinga no https://
, onde ://
faz parte da cadeia de caracteres de consulta, você deve especificar search=https\:\/\/*
. Da mesma forma, um padrão de número de telefone com escape pode ter esta \+1 \(800\) 642\-7676
aparência.
Os caracteres especiais que requerem fuga incluem o seguinte:
+ - & | ! ( ) { } [ ] ^ " ~ * ? : \ /
Nota
Embora a fuga mantenha os tokens juntos, a análise lexical durante a indexação pode eliminá-los. Por exemplo, o analisador Lucene padrão quebrará palavras em hífenes, espaço em branco e outros caracteres. Se você precisar de caracteres especiais na cadeia de caracteres de consulta, talvez precise de um analisador que os preserve no índice. Algumas opções incluem analisadores de linguagem natural da Microsoft, que preserva palavras hifenizadas, ou um analisador personalizado para padrões mais complexos. Para obter mais informações, consulte Termos parciais, padrões e caracteres especiais.
Verifique se todos os caracteres não seguros e reservados estão codificados em uma URL. Por exemplo, #
é um caractere inseguro porque é um identificador de fragmento/âncora em uma URL. O caractere deve ser codificado para %23
se usado em uma URL. &
e =
são exemplos de caracteres reservados à medida que delimitam parâmetros e especificam valores no Azure AI Search. Consulte RFC1738: Uniform Resource Locators (URL) para obter mais detalhes.
Caracteres inseguros são " ` < > # % { } | \ ^ ~ [ ]
. Os caracteres reservados são ; / ? : @ = + &
.
Você pode incorporar operadores booleanos em uma cadeia de caracteres de consulta para melhorar a precisão de uma correspondência. A sintaxe completa suporta operadores de texto, além de operadores de caracteres. Sempre especifique operadores booleanos de texto (AND, OR, NOT) em todas as maiúsculas.
Operador de texto | Caráter | Exemplo | Utilização |
---|---|---|---|
AND | + |
wifi AND luxury |
Especifica os termos que uma correspondência deve conter. No exemplo, o mecanismo de consulta procura documentos que contenham ambos e wifi luxury . O caractere de adição (+ ) também pode ser usado diretamente na frente de um termo para torná-lo necessário. Por exemplo, +wifi +luxury estipula que ambos os termos devem aparecer algures no campo de um único documento. |
OU | (nenhum) 1 | wifi OR luxury |
Encontra uma correspondência quando um dos termos é encontrado. No exemplo, o mecanismo de consulta retorna correspondência em documentos contendo um wifi ou luxury ambos. Como OR é o operador de wifi OR luxury conjunção padrão, você também pode deixá-lo de fora, de modo que wifi luxury é o equivalente a . |
NOT | ! , - |
wifi –luxury |
Devolve uma correspondência em documentos que excluem o termo. Por exemplo, procura documentos que tenham o termo, wifi –luxury mas não luxury .wifi |
1 O |
caractere não é suportado para operações OR.
Importante
O operador NOT (NOT
, !
, ou -
) comporta-se de forma diferente na sintaxe completa do que na sintaxe simples.
- Em sintaxe simples, as consultas com negação sempre têm um curinga adicionado automaticamente. Por exemplo, a consulta
-luxury
é expandida automaticamente para-luxury *
. - Na sintaxe completa, consultas com negação não podem ser combinadas com um curinga. Por exemplo, as consultas não são permitidas
-luxury *
. - Na sintaxe completa, consultas com uma única negação não são permitidas. Por exemplo, a consulta
-luxury
não é permitida. - Na sintaxe completa, as negações se comportarão como se estivessem sempre ANDed na consulta, independentemente do modo de pesquisa.
- Por exemplo, a consulta
wifi -luxury
de sintaxe completa em sintaxe completa busca apenas documentos que contenham o termowifi
e, em seguida, aplica a negação-luxury
a esses documentos.
- Por exemplo, a consulta
- Se você quiser usar negações para pesquisar todos os documentos no índice, recomenda-se uma sintaxe simples com o
any
modo de pesquisa. - Se você quiser usar negações para pesquisar sobre um subconjunto de documentos no índice, recomenda-se sintaxe completa ou a sintaxe simples com o modo de pesquisa todos.
Tipo de consulta | Modo de pesquisa | Exemplo de consulta | Comportamento |
---|---|---|---|
Simples | qualquer | wifi -luxury |
Retorna todos os documentos no índice. Documentos com o termo "wifi" ou documentos sem o termo "luxo" são classificados mais alto do que outros documentos. A consulta é expandida para wifi OR -luxury OR * . |
Simples | todos | wifi -luxury |
Devolve apenas documentos no índice que contêm o termo "wifi" e não contêm o termo "luxo". A consulta é expandida para wifi AND -luxury AND * . |
Total | qualquer | wifi -luxury |
Retorna apenas documentos no índice que contêm o termo "wifi" e, em seguida, os documentos que contêm o termo "luxo" são removidos dos resultados. |
Total | todos | wifi -luxury |
Retorna apenas documentos no índice que contêm o termo "wifi" e, em seguida, os documentos que contêm o termo "luxo" são removidos dos resultados. |
Você pode definir uma operação de pesquisa em campo com a fieldName:searchExpression
sintaxe, onde a expressão de pesquisa pode ser uma única palavra ou frase, ou uma expressão mais complexa entre parênteses, opcionalmente com operadores booleanos. Alguns exemplos incluem o seguinte:
genre:jazz NOT history
artists:("Miles Davis" "John Coltrane")
Certifique-se de colocar várias cadeias entre aspas se quiser que ambas as cadeias sejam avaliadas como uma única entidade, neste caso procurando por dois artistas distintos no artists
campo.
O campo especificado em fieldName:searchExpression
deve ser um searchable
campo. Consulte Criar índice para obter detalhes sobre como os atributos de índice são usados em definições de campo.
Nota
Ao usar expressões de pesquisa em campo, não é necessário usar o searchFields
parâmetro porque cada expressão de pesquisa em campo tem um nome de campo explicitamente especificado. No entanto, você ainda pode usar o searchFields
parâmetro se quiser executar uma consulta em que algumas partes têm escopo para um campo específico, e o restante pode se aplicar a vários campos. Por exemplo, a consulta search=genre:jazz NOT history&searchFields=description
corresponderia jazz
apenas ao genre
campo, enquanto corresponderia NOT history
ao description
campo. O nome do campo fornecido em fieldName:searchExpression
sempre tem precedência sobre o searchFields
parâmetro, e é por isso que, neste exemplo, não precisamos incluir genre
no searchFields
parâmetro.
Uma pesquisa difusa encontra correspondências em termos que têm uma construção semelhante, expandindo um termo até o máximo de 50 termos que atendem aos critérios de distância de dois ou menos. Para obter mais informações, consulte Pesquisa difusa.
Para fazer uma pesquisa difusa, use o símbolo til no final de uma única palavra com um parâmetro opcional, um número entre 0 e 2 (padrão), que especifica a distância de ~
edição. Por exemplo, blue~
ou blue~1
retornaria blue
, blues
, e glue
.
A pesquisa difusa só pode ser aplicada a termos, não a frases entre aspas, mas você pode acrescentar o til a cada termo individualmente em um nome ou frase com várias partes. Por exemplo, Unviersty~ of~ Wshington~
corresponderia em University of Washington
.
As pesquisas de proximidade são usadas para encontrar termos próximos uns dos outros em um documento. Insira um símbolo til no final de uma frase seguido pelo número de palavras que criam o limite de ~
proximidade. Por exemplo, "hotel airport"~5
localiza os termos hotel
e airport
dentro de cinco palavras um do outro em um documento.
Aumento de termos refere-se à classificação mais alta de um documento se ele contiver o termo impulsionado, em relação aos documentos que não contêm o termo. Isso difere dos perfis de pontuação, pois os perfis de pontuação impulsionam determinados campos, em vez de termos específicos.
O exemplo a seguir ajuda a ilustrar as diferenças. Suponha que haja um perfil de pontuação que aumente as correspondências em um determinado campo, digamos gênero no exemplo musicstoreindex. O aumento de termos pode ser usado para impulsionar ainda mais certos termos de pesquisa do que outros. Por exemplo, rock^2 electronic
impulsiona documentos que contêm os termos de pesquisa no campo de gênero mais alto do que outros campos pesquisáveis no índice. Além disso, os documentos que contêm o termo de pesquisa rock são classificados mais alto do que o outro termo de pesquisa eletrônico como resultado do valor de impulso do termo (2).
Para impulsionar um termo, use o acento circunflexo, ^
símbolo com um fator de impulso (um número) no final do termo que você está pesquisando. Você também pode impulsionar frases. Quanto maior o fator de impulso, mais relevante o termo é em relação a outros termos de pesquisa. O fator de potência predefinido é 1. Embora o fator de impulso deva ser positivo, pode ser inferior a 1 (por exemplo, 0,20).
Uma pesquisa de expressão regular encontra uma correspondência com base em padrões que são válidos no Apache Lucene, conforme documentado na classe RegExp.
No Azure AI Search, uma expressão regular é:
- Fechado entre barras para a frente
/
- Apenas minúsculas
Por exemplo, para localizar documentos que contenham motel
ou hotel
, especifique /[mh]otel/
. As pesquisas de expressões regulares são comparadas com palavras únicas.
Algumas ferramentas e linguagens impõem requisitos de caracteres de escape adicionais além das regras de escape impostas pelo Azure AI Search. Para JSON, as cadeias de caracteres que incluem uma barra são escapadas com uma barra invertida: microsoft.com/azure/
torna-se search=/.*microsoft.com\/azure\/.*/
onde search=/.* <string-placeholder>.*/
configura a expressão regular e microsoft.com\/azure\/
é a cadeia de caracteres com uma barra para frente com escape.
Dois símbolos comuns em consultas regex são .
e *
. A .
corresponde a qualquer caractere e a *
corresponde ao caractere anterior zero ou mais vezes. Por exemplo, /be./
corresponde aos termos bee
e bet
while /be*/
corresponderia a be
, bee
e beee
mas não bet
. Juntos, .*
permitem que você corresponda a qualquer série de caracteres para corresponder a /be.*/
qualquer termo que comece com be
.better
Se você receber erros de sintaxe em sua expressão regular, revise as regras de escape para caracteres especiais. Você também pode tentar um cliente diferente para confirmar se o problema é específico da ferramenta.
Você pode usar a sintaxe geralmente reconhecida para pesquisas curinga de vários caracteres (*
) ou únicos (?
). A sintaxe Lucene completa suporta correspondência de prefixo e infix. Use a sintaxe de expressão regular para correspondência de sufixos.
Observe que o analisador de consulta Lucene suporta o uso desses símbolos com um único termo e não com uma frase.
Tipo de afixo | Descrição e exemplos |
---|---|
prefixo | O termo fragmento vem antes * ou ? . Por exemplo, uma expressão de consulta de search=alpha* retornos alphanumeric ou alphabetical . A correspondência de prefixos é suportada em sintaxe simples e completa. |
sufixo | O termo fragmento vem depois * ou ? , com uma barra para delimitar a construção. Por exemplo, search=/.*numeric/ retorna alphanumeric . |
Infix | Os fragmentos de termo incluem * ou ? . Por exemplo, search=non*al devoluções non-numerical e nonsensical . |
Você pode combinar operadores em uma expressão. Por exemplo, 980?2*
correspondências em 98072-1222
e 98052-1234
, onde ?
corresponde a um único caractere (obrigatório) e *
corresponde a caracteres de comprimento arbitrário que se seguem.
A correspondência de sufixos requer os delimitadores de barra /
para a frente da expressão regular. Geralmente, não é possível usar um *
símbolo ou ?
como o primeiro caractere de um termo, sem o /
. Também é importante notar que o *
se comporta de forma diferente quando usado fora das consultas regex. Fora do delimitador de barras /
para frente regex, o é um caractere curinga e corresponde a qualquer série de caracteres muito parecido .*
com o *
regex. Como exemplo, search=/non.*al/
produz o mesmo conjunto de resultados que search=non*al
.
Nota
Como regra, a correspondência de padrões é lenta, então você pode querer explorar métodos alternativos, como a tokenização de n-grama de borda que cria tokens para sequências de caracteres em um termo. Com a tokenização de n-gramas, o índice será maior, mas as consultas podem ser executadas mais rapidamente, dependendo da construção do padrão e do comprimento das cadeias de caracteres que você está indexando. Para obter mais informações, veja Pesquisa parcial de termos e padrões com carateres especiais.
Durante a análise da consulta, as consultas formuladas como prefixo, sufixo, curinga ou expressões regulares são passadas como estão para a árvore de consulta, ignorando a análise lexical. As correspondências só serão encontradas se o índice contiver as cadeias de caracteres no formato especificado pela consulta. Na maioria dos casos, você precisa de um analisador durante a indexação que preserve a integridade da cadeia de caracteres para que a correspondência parcial de termos e padrões seja bem-sucedida. Para obter mais informações, consulte Pesquisa parcial de termos em consultas do Azure AI Search.
Considere uma situação em que você pode desejar que a consulta terminal*
de pesquisa retorne resultados que contenham termos como terminate
, termination
e terminates
.
Se você usasse o analisador en.lucene (inglês Lucene), ele aplicaria derivação agressiva de cada termo. Por exemplo, terminate
, termination
, terminates
todos serão tokenizados até o token termi
em seu índice. Por outro lado, os termos em consultas que usam curingas ou pesquisa difusa não são analisados, portanto, não haveria resultados que correspondessem à terminat*
consulta.
Por outro lado, os analisadores da Microsoft (neste caso, o analisador en.microsoft) são um pouco mais avançados e usam lemmatização em vez de derivar. Isso significa que todos os tokens gerados devem ser palavras válidas em inglês. Por exemplo, terminate
, terminates
e termination
permanecerá praticamente inteiro no índice, e seria uma escolha preferível para cenários que dependem muito de curingas e pesquisa difusa.
O Azure AI Search usa pontuação baseada em frequência (BM25) para consultas de texto. No entanto, para consultas curinga e regex em que o escopo dos termos pode ser potencialmente amplo, o fator de frequência é ignorado para evitar que a classificação tenda para correspondências de termos mais raros. Todas as correspondências são tratadas igualmente para pesquisas curinga e regex.
Em algumas circunstâncias, você pode querer procurar por um caractere especial, como um emoji '❤' ou o sinal '€'. Nesses casos, certifique-se de que o analisador usado não filtre esses caracteres. O analisador padrão ignora muitos caracteres especiais, excluindo-os do seu índice.
Os analisadores que tokenizam caracteres especiais incluem o analisador de espaço em branco, que leva em consideração quaisquer sequências de caracteres separadas por espaços em branco como tokens (portanto, a ❤
cadeia de caracteres seria considerada um token). Além disso, um analisador de linguagem como o Microsoft English Analyzer ("en.microsoft"), tomaria a string "€" como um token. Você pode testar um analisador para ver quais tokens ele gera para uma determinada consulta.
Ao usar caracteres Unicode, certifique-se de que os símbolos são escapados corretamente na url de consulta (por exemplo, para ❤
usar a sequência %E2%9D%A4+
de escape ). Alguns clientes REST fazem essa tradução automaticamente.
Você pode usar parênteses para criar subconsultas, incluindo operadores dentro da instrução entre parênteses. Por exemplo, motel+(wifi|luxury)
procura documentos que contenham o motel
termo e um wifi
ou ( luxury
ou ambos).
O agrupamento de campos é semelhante, mas define o escopo do agrupamento para um único campo. Por exemplo, hotelAmenities:(gym+(wifi|pool))
pesquisa no campo hotelAmenities
por gym
e wifi
, ou gym
e pool
.
O Azure AI Search impõe limites ao tamanho e à composição da consulta porque consultas não limitadas podem desestabilizar o seu serviço de pesquisa. Há limites para o tamanho e a composição da consulta (o número de cláusulas). Também existem limites para o comprimento da pesquisa de prefixo e para a complexidade da pesquisa regex e da pesquisa curinga. Se seu aplicativo gera consultas de pesquisa programaticamente, recomendamos projetá-lo de tal forma que não gere consultas de tamanho ilimitado.
Para obter mais informações sobre limites de consulta, consulte Limites de solicitação de API.