Textindex der AnfĂŒhrungszeichen im Speicher in Go

Vor kurzem musste ich tatsĂ€chlich eine Suche am Anfang eines Strings implementieren WHERE name LIKE '%'. Es war eine Suche nach den Namen der Austauschsymbole (AAPL, AMZN, EUR / USD usw.). Ich wollte, dass die Suche schnell funktioniert und die Datenbank nicht erneut geladen wird. Infolgedessen bin ich zur Implementierung der Baumsuche im Speicher gekommen, und ich werde Ihnen darĂŒber erzĂ€hlen.

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 . , .

, .

.

  1. .

  2. .

  3. .

  4. .

  5. , , ã → a.

  6. - ().

, — , .

, Index.Data .

. — Index.Children , ( — ). , AAPL, ( ):

[A], [A], [P], [L]. , . , .

, . , . , .

.

, — . .

  1. (. ).

  2. , . 

  3. .

, 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 .

  1. .

  2. , .

  3. , .

  4. , .

, . .

  1. SearchSymbolIndex .

  2. SearchPopularIndex (10% ).

  3. 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 ), .

Diese Suche wird derzeit in der Finanz-API fĂŒr Entwickler verwendet. Ein Beispiel finden Sie auf dieser Seite, auf der Sie es live ausprobieren können.




All Articles