diff --git a/services/horizon/internal/db2/history/main.go b/services/horizon/internal/db2/history/main.go index 10eb423290..5f50110e2a 100644 --- a/services/horizon/internal/db2/history/main.go +++ b/services/horizon/internal/db2/history/main.go @@ -879,6 +879,24 @@ func (q Q) ReapLookupTables(ctx context.Context, offsets map[string]int64) ( objectField: "history_account_id", }, }, + "history_assets": { + { + name: "history_trades", + objectField: "base_asset_id", + }, + { + name: "history_trades", + objectField: "counter_asset_id", + }, + { + name: "history_trades_60000", + objectField: "base_asset_id", + }, + { + name: "history_trades_60000", + objectField: "counter_asset_id", + }, + }, "history_claimable_balances": { { name: "history_operation_claimable_balances", diff --git a/services/horizon/internal/db2/history/reap_test.go b/services/horizon/internal/db2/history/reap_test.go index 5e62dc606f..88dc69c273 100644 --- a/services/horizon/internal/db2/history/reap_test.go +++ b/services/horizon/internal/db2/history/reap_test.go @@ -22,6 +22,7 @@ func TestReapLookupTables(t *testing.T) { var ( prevLedgers, curLedgers int prevAccounts, curAccounts int + prevAssets, curAssets int prevClaimableBalances, curClaimableBalances int prevLiquidityPools, curLiquidityPools int ) @@ -32,6 +33,8 @@ func TestReapLookupTables(t *testing.T) { tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &prevAccounts, `SELECT COUNT(*) FROM history_accounts`) tt.Require.NoError(err) + err = db.GetRaw(tt.Ctx, &prevAssets, `SELECT COUNT(*) FROM history_assets`) + tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &prevClaimableBalances, `SELECT COUNT(*) FROM history_claimable_balances`) tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &prevLiquidityPools, `SELECT COUNT(*) FROM history_liquidity_pools`) @@ -60,6 +63,8 @@ func TestReapLookupTables(t *testing.T) { tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &curAccounts, `SELECT COUNT(*) FROM history_accounts`) tt.Require.NoError(err) + err = db.GetRaw(tt.Ctx, &curAssets, `SELECT COUNT(*) FROM history_assets`) + tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &curClaimableBalances, `SELECT COUNT(*) FROM history_claimable_balances`) tt.Require.NoError(err) err = db.GetRaw(tt.Ctx, &curLiquidityPools, `SELECT COUNT(*) FROM history_liquidity_pools`) @@ -73,6 +78,10 @@ func TestReapLookupTables(t *testing.T) { tt.Assert.Equal(1, curAccounts, "curAccounts") tt.Assert.Equal(int64(24), deletedCount["history_accounts"], `deletedCount["history_accounts"]`) + tt.Assert.Equal(7, prevAssets, "prevAssets") + tt.Assert.Equal(0, curAssets, "curAssets") + tt.Assert.Equal(int64(7), deletedCount["history_assets"], `deletedCount["history_assets"]`) + tt.Assert.Equal(1, prevClaimableBalances, "prevClaimableBalances") tt.Assert.Equal(0, curClaimableBalances, "curClaimableBalances") tt.Assert.Equal(int64(1), deletedCount["history_claimable_balances"], `deletedCount["history_claimable_balances"]`) @@ -81,8 +90,9 @@ func TestReapLookupTables(t *testing.T) { tt.Assert.Equal(0, curLiquidityPools, "curLiquidityPools") tt.Assert.Equal(int64(1), deletedCount["history_liquidity_pools"], `deletedCount["history_liquidity_pools"]`) - tt.Assert.Len(newOffsets, 3) + tt.Assert.Len(newOffsets, 4) tt.Assert.Equal(int64(0), newOffsets["history_accounts"]) + tt.Assert.Equal(int64(0), newOffsets["history_assets"]) tt.Assert.Equal(int64(0), newOffsets["history_claimable_balances"]) tt.Assert.Equal(int64(0), newOffsets["history_liquidity_pools"]) } diff --git a/services/horizon/internal/db2/schema/60_add_asset_id_indexes.sql b/services/horizon/internal/db2/schema/60_add_asset_id_indexes.sql new file mode 100644 index 0000000000..7086c3fede --- /dev/null +++ b/services/horizon/internal/db2/schema/60_add_asset_id_indexes.sql @@ -0,0 +1,9 @@ +-- +migrate Up + +CREATE INDEX "htrd_by_counter_asset" ON history_trades USING btree (counter_asset_id); +CREATE INDEX "htrd_agg_counter_asset" ON history_trades_60000 USING btree (counter_asset_id); + +-- +migrate Down + +DROP INDEX "htrd_by_counter_asset"; +DROP INDEX "htrd_agg_counter_asset";