Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Index selectors #96

Merged
merged 45 commits into from
Apr 11, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
3771e81
Query.Intersect API & test
marino39 Mar 20, 2023
fa6c2ef
Naive implementation of Query.Intersects
marino39 Mar 20, 2023
a220743
Improve Query.Intersect benchmark
marino39 Mar 20, 2023
8968be7
Query.Intersect add sort / filter / offset / limit
marino39 Mar 20, 2023
c14e8ea
Index.Iter implementation
marino39 Mar 21, 2023
4dac79b
Use Index.Iter in Table Scan functions
marino39 Mar 21, 2023
490f432
Extract index update functions from Table to Index
marino39 Mar 21, 2023
e5db7e4
Extract index update functions from Table to Index: p2
marino39 Mar 21, 2023
13e42f5
KeySuccessor args change
marino39 Mar 21, 2023
a4bd17a
Fix: allocations is Table.PrimaryKey
marino39 Mar 21, 2023
ac937b9
Optimize Index.OnUpdate, so it requires less writes to database
marino39 Mar 22, 2023
3a4ee78
Use new Index callbacks in Table.reindex func
marino39 Mar 22, 2023
7a50e94
Add Intersect function to Index and use it in Query
marino39 Mar 22, 2023
80b2d1d
Benchmark Query.Intersect
marino39 Mar 23, 2023
e16bdc8
Move Index.Intersects to be map based because of poor performance
marino39 Mar 23, 2023
d8aa922
Reduce number of allocations in Index.Intersect
marino39 Mar 23, 2023
11e01d1
Add Query.Intersect().Order() test
marino39 Mar 23, 2023
fd5ce51
Query.Intersect().After() implementation
marino39 Mar 23, 2023
365ad1c
Query.After now works with Query.Order and Query.Intersect
marino39 Mar 24, 2023
323c907
Make sure that intersect queries do not have any modifiers like limit…
marino39 Mar 27, 2023
d39c691
Index selectors API proposition
marino39 Mar 27, 2023
d98773b
Merge branch 'master' into new_index_selectors
marino39 Mar 29, 2023
6f43140
Selector struct impl
marino39 Mar 29, 2023
8aa787f
Selector interface based approach
marino39 Mar 30, 2023
2790aa8
Table / Index.Intersect ported to use Selector
marino39 Mar 30, 2023
6afb4a8
Add table utils unit test
marino39 Mar 30, 2023
58fe15e
Use Selector in Query
marino39 Mar 30, 2023
863df97
Add files to .gitignore
marino39 Mar 30, 2023
cda655e
Fix: Example app
marino39 Mar 30, 2023
80b0f91
Cleanup
marino39 Mar 30, 2023
f63efaf
Table.Get SelectorRange implementation
marino39 Mar 31, 2023
0ca9793
Table.Get SelectorPoints implementation
marino39 Mar 31, 2023
a002c93
Table.Get SelectorPoints implementation -- add one more benchmark
marino39 Mar 31, 2023
9abce7e
Table.Get SelectorRanges implementation
marino39 Apr 4, 2023
0781cc7
Index.Iter unit tests
marino39 Apr 5, 2023
cdcb795
Index.Iter unit tests - PrimaryIndex
marino39 Apr 5, 2023
f38b78a
Index.Iter unit tests - new concept of Point Iter for primary index &…
marino39 Apr 5, 2023
a319514
Index.Iter restore SelectorPoints impl & unit tests
marino39 Apr 6, 2023
3f29335
Index OnInsert/OnUpdate/OnDelete unit tests
marino39 Apr 6, 2023
e8b19d2
Fix: Index.OnUpdate not properly updating indexes
marino39 Apr 6, 2023
40d552c
Update README.md
marino39 Apr 7, 2023
4e25ee3
Update comment in selector.go for SelectorRange and SelectorRanges
marino39 Apr 7, 2023
699851e
Fix: Issue with Query, SelectorRanges and Query.After
marino39 Apr 7, 2023
3bde6d3
Remove no longer valid test case
marino39 Apr 7, 2023
f8a2ab1
Query tests with different selectors and Query.After
marino39 Apr 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Index selectors API proposition
They are used to select part of the index to be iterated or returned
  • Loading branch information
marino39 committed Mar 27, 2023
commit d39c691757cf432914d85b5d3d2abbe71427a11c
21 changes: 21 additions & 0 deletions index.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,27 @@ func IndexOrderDefault[T any](o IndexOrder, t T) IndexOrder {
return o
}

type IndexSelector[T any] interface {
Next() (T, T)
Valid() bool
}

type IndexSelectorPoint[T any] struct {
Points []T
}

func NewIndexSelectorPoints[T any](points ...T) IndexSelectorPoint[T] {
return IndexSelectorPoint[T]{Points: points}
}

type IndexSelectorRange[T any] struct {
Ranges [][]T
}

func NewIndexSelectorRanges[T any](ranges ...[]T) IndexSelectorRange[T] {
return IndexSelectorRange[T]{Ranges: ranges}
}

const PrimaryIndexID = IndexID(0)
const PrimaryIndexName = "primary"

Expand Down
79 changes: 79 additions & 0 deletions index_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -479,6 +479,85 @@ func TestIndexOrder_Multi(t *testing.T) {
assert.Equal(t, expectedKeyList, keyList)
}

func TestBond_IndexSelector(t *testing.T) {
/*
// Index Selector (already in bond, however with different api)
// idx1: index on AccountAddress
// Selects all records where AccountAddress == account1
Table.Query().
With(
idx1,
NewIndexSelectorPoints[*TokenBalance](
&TokenBalance{AccountAddress: "account1"},
),
).
Execute()

// Index Selector
// idx1: index on AccountAddress
// Selects records for AccountAddress IN [account1, account8, account10]
Table.Query().
With(
idx1,
NewIndexSelectorPoints[*TokenBalance](
&TokenBalance{AccountAddress: "account1"},
&TokenBalance{AccountAddress: "account8"},
&TokenBalance{AccountAddress: "account10"},
),
).
Execute()

// Range Index Selector
// idx2: index on ContractAddress & TokenID
// Selects all records with ContractAddress == contract0 and 0 <= TokenID < math.MaxUint64
Table.Query().
With(
idx2,
NewIndexSelectorRanges[*TokenBalance](
[]*TokenBalance{
{ContractAddress: "contract0", TokenID: 0},
{ContractAddress: "contract0", TokenID: math.MaxUint64},
},
),
).
Execute()

// Range Index Selector
// idx2: index on ContractAddress & TokenID
// Selects all records with ContractAddress == contract0 and TokenID >= 25
Table.Query().
With(
idx2,
NewIndexSelectorRanges[*TokenBalance](
[]*TokenBalance{
{ContractAddress: "contract0", TokenID: 25},
{ContractAddress: "contract0", TokenID: math.MaxUint64},
},
),
).
Execute()

// Range Index Selector
// idx2: index on ContractAddress & TokenID
// Selects all records with ContractAddress == contract0 and TokenID < 20 and TokenID >= 25
Table.Query().
With(
idx2,
NewIndexSelectorRanges[*TokenBalance](
[]*TokenBalance{
{ContractAddress: "contract0", TokenID: 0},
{ContractAddress: "contract0", TokenID: 20},
},
[]*TokenBalance{
{ContractAddress: "contract0", TokenID: 25},
{ContractAddress: "contract0", TokenID: math.MaxUint64},
},
),
).
Execute()
*/
}

func TestBond_NewIndex(t *testing.T) {
const (
TokenBalanceAccountIDIndexID = IndexID(1)
Expand Down