Recentemente precisei implementar uma busca pelo início de uma string, na verdade WHERE name LIKE '%'. Foi uma busca pelo nome dos símbolos de câmbio (AAPL, AMZN, EUR / USD, etc.). Eu queria que a pesquisa funcionasse rapidamente e não carregasse o banco de dados novamente. Como resultado, cheguei à implementação da busca em árvore na memória e vou falar sobre isso.
55000 ( ). . , .
. , BTree, ( , , , trie), — . , .
. , .
.
, , . , , :
AAA (BetaShares Australian High Interest Cash ETF, ASX),
AAA (All Active Asset Capital LTD, LSE).
Index.Data , Index.Data AAA.
SearchIndex.Data . , .
, .
.
.
.
.
.
, , ã → a.
- ().
, — , .
, Index.Data .
. — Index.Children , ( — ). , AAPL, ( ):
[A], [A], [P], [L]. , . , .
, . , . , .
.
, — . .
(. ).
, .
.
, AA, :
AAL
AAALF
AAAP
AAB
AAP
AAPJ
AAPL
AAPT
, AA. .
WHERE name LIKE '%'. , , .
“EUR”, “EUR”, “EUR/USD”, “USD/EUR”. , .
, . , “APL”, “APL”, “AAPL” (Apple).
.
“EUR”, “EUR”, “EUR/USD”, “USD/EUR”, : . , “USD/EUR”, : “usd eur”, “eur”. “Grupo Financiero Galicia SA” “Grupo Financiero Galicia SA”, “Financiero Galicia SA”, “Galicia SA”, “SA”.
, 4 .
.
, .
, .
, .
, . .
SearchSymbolIndex.SearchPopularIndex(10% ).SearchInstrumentIndex.
— .
var searchedData []searchindex.SearchData
searchedData = r.SearchSymbolIndex.Search(searchindex.SearchParams{
Text: key,
OutputSize: outputSize,
Matching: searchsymbol.Strict,
})
searchedData = r.SearchPopularIndex.Search(searchindex.SearchParams{
Text: key,
OutputSize: outputSize,
Matching: searchsymbol.Beginning,
StartValues: searchedData,
})
searchedData = r.SearchSymbolIndex.Search(searchindex.SearchParams{
Text: key,
OutputSize: outputSize,
Matching: searchindex.Beginning,
StartValues: searchedData,
})
searchedData = r.SearchInstrumentIndex.Search(searchindex.SearchParams{
Text: key,
OutputSize: outputSize,
Matching: searchindex.Beginning,
StartValues: searchedData,
})StartValues — , , , , , (OutputSize).
searchindex.Strict — .
searchindex.Beginning — .
, . 300 . , .
, 55000 2 , . 4 100-200 ( http ), .
Esta pesquisa é usada atualmente na API financeira para desenvolvedores. Um exemplo pode ser visto nesta página onde você pode experimentá-la ao vivo.