mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-20 15:11:36 +01:00
Optimize unsatisfied condition removal for players with user_id join
The query was joining based on UUID which can be slow since it's a string.
This commit is contained in:
parent
47d74eee8c
commit
4615c6b6b0
@ -17,6 +17,7 @@
|
|||||||
package com.djrapitops.plan.extension.implementation.storage.transactions.results;
|
package com.djrapitops.plan.extension.implementation.storage.transactions.results;
|
||||||
|
|
||||||
import com.djrapitops.plan.storage.database.DBType;
|
import com.djrapitops.plan.storage.database.DBType;
|
||||||
|
import com.djrapitops.plan.storage.database.sql.tables.UsersTable;
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.extension.*;
|
import com.djrapitops.plan.storage.database.sql.tables.extension.*;
|
||||||
import com.djrapitops.plan.storage.database.transactions.ExecStatement;
|
import com.djrapitops.plan.storage.database.transactions.ExecStatement;
|
||||||
import com.djrapitops.plan.storage.database.transactions.Executable;
|
import com.djrapitops.plan.storage.database.transactions.Executable;
|
||||||
@ -69,17 +70,19 @@ public class RemoveUnsatisfiedConditionalPlayerResultsTransaction extends Throwa
|
|||||||
String selectSatisfiedPositiveConditions = SELECT +
|
String selectSatisfiedPositiveConditions = SELECT +
|
||||||
ExtensionProviderTable.PROVIDED_CONDITION + ',' +
|
ExtensionProviderTable.PROVIDED_CONDITION + ',' +
|
||||||
ExtensionProviderTable.PLUGIN_ID + ',' +
|
ExtensionProviderTable.PLUGIN_ID + ',' +
|
||||||
ExtensionPlayerTableValueTable.USER_UUID +
|
"u." + UsersTable.ID + " as user_id" +
|
||||||
FROM + providerTable +
|
FROM + providerTable +
|
||||||
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
||||||
|
INNER_JOIN + UsersTable.TABLE_NAME + " u on u." + UsersTable.USER_UUID + "=" + playerValueTable + "." + ExtensionPlayerTableValueTable.USER_UUID +
|
||||||
WHERE + ExtensionPlayerValueTable.BOOLEAN_VALUE + "=?" +
|
WHERE + ExtensionPlayerValueTable.BOOLEAN_VALUE + "=?" +
|
||||||
AND + ExtensionProviderTable.PROVIDED_CONDITION + IS_NOT_NULL;
|
AND + ExtensionProviderTable.PROVIDED_CONDITION + IS_NOT_NULL;
|
||||||
String selectSatisfiedNegativeConditions = SELECT +
|
String selectSatisfiedNegativeConditions = SELECT +
|
||||||
reversedCondition + " as " + ExtensionProviderTable.PROVIDED_CONDITION + ',' +
|
reversedCondition + " as " + ExtensionProviderTable.PROVIDED_CONDITION + ',' +
|
||||||
ExtensionProviderTable.PLUGIN_ID + ',' +
|
ExtensionProviderTable.PLUGIN_ID + ',' +
|
||||||
ExtensionPlayerTableValueTable.USER_UUID +
|
"u." + UsersTable.ID + " as user_id" +
|
||||||
FROM + providerTable +
|
FROM + providerTable +
|
||||||
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
||||||
|
INNER_JOIN + UsersTable.TABLE_NAME + " u on u." + UsersTable.USER_UUID + "=" + playerValueTable + "." + ExtensionPlayerTableValueTable.USER_UUID +
|
||||||
WHERE + ExtensionPlayerValueTable.BOOLEAN_VALUE + "=?" +
|
WHERE + ExtensionPlayerValueTable.BOOLEAN_VALUE + "=?" +
|
||||||
AND + ExtensionProviderTable.PROVIDED_CONDITION + IS_NOT_NULL;
|
AND + ExtensionProviderTable.PROVIDED_CONDITION + IS_NOT_NULL;
|
||||||
|
|
||||||
@ -99,14 +102,12 @@ public class RemoveUnsatisfiedConditionalPlayerResultsTransaction extends Throwa
|
|||||||
String selectUnsatisfiedValueIDs = SELECT + playerValueTable + '.' + ExtensionPlayerValueTable.ID +
|
String selectUnsatisfiedValueIDs = SELECT + playerValueTable + '.' + ExtensionPlayerValueTable.ID +
|
||||||
FROM + providerTable +
|
FROM + providerTable +
|
||||||
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
INNER_JOIN + playerValueTable + " on " + providerTable + '.' + ExtensionProviderTable.ID + "=" + ExtensionPlayerValueTable.PROVIDER_ID +
|
||||||
|
INNER_JOIN + UsersTable.TABLE_NAME + " u on u." + UsersTable.USER_UUID + "=" + playerValueTable + "." + ExtensionPlayerTableValueTable.USER_UUID +
|
||||||
LEFT_JOIN + selectSatisfiedConditions + // Left join to preserve values that don't have their condition fulfilled
|
LEFT_JOIN + selectSatisfiedConditions + // Left join to preserve values that don't have their condition fulfilled
|
||||||
" on (" + // Join when uuid and plugin_id match and condition for the group provider is satisfied
|
" on (" + // Join when uuid and plugin_id match and condition for the group provider is satisfied
|
||||||
playerValueTable + '.' + ExtensionPlayerValueTable.USER_UUID +
|
"u." + UsersTable.ID + "=q1.user_id" +
|
||||||
"=q1." + ExtensionPlayerValueTable.USER_UUID +
|
AND + ExtensionProviderTable.CONDITION + "=q1." + ExtensionProviderTable.PROVIDED_CONDITION +
|
||||||
AND + ExtensionProviderTable.CONDITION +
|
AND + providerTable + '.' + ExtensionProviderTable.PLUGIN_ID + "=q1." + ExtensionProviderTable.PLUGIN_ID +
|
||||||
"=q1." + ExtensionProviderTable.PROVIDED_CONDITION +
|
|
||||||
AND + providerTable + '.' + ExtensionProviderTable.PLUGIN_ID +
|
|
||||||
"=q1." + ExtensionProviderTable.PLUGIN_ID +
|
|
||||||
')' +
|
')' +
|
||||||
WHERE + "q1." + ExtensionProviderTable.PROVIDED_CONDITION + IS_NULL + // Conditions that were not in the satisfied condition query
|
WHERE + "q1." + ExtensionProviderTable.PROVIDED_CONDITION + IS_NULL + // Conditions that were not in the satisfied condition query
|
||||||
AND + ExtensionProviderTable.CONDITION + IS_NOT_NULL; // Ignore values that don't need condition
|
AND + ExtensionProviderTable.CONDITION + IS_NOT_NULL; // Ignore values that don't need condition
|
||||||
@ -162,11 +163,11 @@ public class RemoveUnsatisfiedConditionalPlayerResultsTransaction extends Throwa
|
|||||||
// selectSatisfiedConditions lists 'provided_condition' Strings
|
// selectSatisfiedConditions lists 'provided_condition' Strings
|
||||||
String selectUnsatisfiedIDs = SELECT + groupTable + '.' + ID +
|
String selectUnsatisfiedIDs = SELECT + groupTable + '.' + ID +
|
||||||
FROM + groupTable +
|
FROM + groupTable +
|
||||||
|
INNER_JOIN + UsersTable.TABLE_NAME + " u on u." + UsersTable.USER_UUID + "=" + groupTable + "." + ExtensionGroupsTable.USER_UUID +
|
||||||
INNER_JOIN + providerTable + " on " + providerTable + '.' + ID + '=' + groupTable + '.' + ExtensionGroupsTable.PROVIDER_ID +
|
INNER_JOIN + providerTable + " on " + providerTable + '.' + ID + '=' + groupTable + '.' + ExtensionGroupsTable.PROVIDER_ID +
|
||||||
LEFT_JOIN + selectSatisfiedConditions + // Left join to preserve values that don't have their condition fulfilled
|
LEFT_JOIN + selectSatisfiedConditions + // Left join to preserve values that don't have their condition fulfilled
|
||||||
" on (" + // Join when uuid and plugin_id match and condition for the group provider is satisfied
|
" on (" + // Join when uuid and plugin_id match and condition for the group provider is satisfied
|
||||||
groupTable + '.' + P_UUID +
|
"u." + UsersTable.ID + "=q1.user_id" +
|
||||||
"=q1." + P_UUID +
|
|
||||||
AND + ExtensionProviderTable.CONDITION +
|
AND + ExtensionProviderTable.CONDITION +
|
||||||
"=q1." + ExtensionProviderTable.PROVIDED_CONDITION +
|
"=q1." + ExtensionProviderTable.PROVIDED_CONDITION +
|
||||||
AND + providerTable + '.' + ExtensionProviderTable.PLUGIN_ID +
|
AND + providerTable + '.' + ExtensionProviderTable.PLUGIN_ID +
|
||||||
|
@ -209,6 +209,8 @@ public interface ExtensionsDatabaseTest extends DatabaseTestPreparer {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
default void unsatisfiedPlayerConditionalResultsAreCleaned() {
|
default void unsatisfiedPlayerConditionalResultsAreCleaned() {
|
||||||
|
db().executeTransaction(new PlayerRegisterTransaction(playerUUID, System::currentTimeMillis, TestConstants.PLAYER_ONE_NAME));
|
||||||
|
|
||||||
ExtensionSvc extensionService = extensionService();
|
ExtensionSvc extensionService = extensionService();
|
||||||
|
|
||||||
extensionService.register(new ConditionalExtension());
|
extensionService.register(new ConditionalExtension());
|
||||||
|
Loading…
Reference in New Issue
Block a user