From 906940948bfdc095cf5e001e2c3b6cdfa5cb6cce Mon Sep 17 00:00:00 2001 From: Jaanus Sellin Date: Thu, 13 Jun 2024 13:46:06 +0300 Subject: [PATCH] feat: optimize search (#7387) I am moving the strategies join to later part of query, because it is not used for filtering, only need it for data. --- .../feature-search/feature-search-store.ts | 26 ++++++++++--------- 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/lib/features/feature-search/feature-search-store.ts b/src/lib/features/feature-search/feature-search-store.ts index 5dd2dcf33a..ef56e09c9f 100644 --- a/src/lib/features/feature-search/feature-search-store.ts +++ b/src/lib/features/feature-search/feature-search-store.ts @@ -164,12 +164,6 @@ class FeatureSearchStore implements IFeatureSearchStore { selectColumns = [ ...selectColumns, - this.db.raw( - 'has_strategies.feature_name IS NOT NULL AS has_strategies', - ), - this.db.raw( - 'enabled_strategies.feature_name IS NOT NULL AS has_enabled_strategies', - ), this.db.raw(`CASE WHEN dependent_features.parent = features.name THEN 'parent' WHEN dependent_features.child = features.name THEN 'child' @@ -248,8 +242,6 @@ class FeatureSearchStore implements IFeatureSearchStore { 'features.created_by_user_id', ); - this.applyStrategiesByEnvironment(query); - query.leftJoin('last_seen_at_metrics', function () { this.on( 'last_seen_at_metrics.environment', @@ -329,6 +321,8 @@ class FeatureSearchStore implements IFeatureSearchStore { .joinRaw('CROSS JOIN total_features') .whereBetween('final_rank', [offset + 1, offset + limit]) .orderBy('final_rank'); + + this.applyStrategiesByEnvironment(finalQuery); if (featureLifecycleEnabled) { finalQuery.leftJoin( 'lifecycle', @@ -357,6 +351,14 @@ class FeatureSearchStore implements IFeatureSearchStore { } private applyStrategiesByEnvironment(queryBuilder: Knex.QueryBuilder) { + queryBuilder.select( + this.db.raw( + 'has_strategies.feature_name IS NOT NULL AS has_strategies', + ), + this.db.raw( + 'enabled_strategies.feature_name IS NOT NULL AS has_enabled_strategies', + ), + ); queryBuilder .leftJoin( this.db @@ -370,11 +372,11 @@ class FeatureSearchStore implements IFeatureSearchStore { this.on( 'enabled_strategies.feature_name', '=', - 'features.name', + 'ranked_features.feature_name', ).andOn( 'enabled_strategies.environment', '=', - 'feature_environments.environment', + 'ranked_features.environment', ); }, ) @@ -388,11 +390,11 @@ class FeatureSearchStore implements IFeatureSearchStore { this.on( 'has_strategies.feature_name', '=', - 'features.name', + 'ranked_features.feature_name', ).andOn( 'has_strategies.environment', '=', - 'feature_environments.environment', + 'ranked_features.environment', ); }, );