Increased Extension table value lengths to 250 chars

This commit is contained in:
Rsl1122 2019-09-05 18:15:33 +03:00
parent 2da10001dc
commit 209530be4d
8 changed files with 124 additions and 13 deletions

View File

@ -26,6 +26,7 @@ import com.djrapitops.plan.storage.database.transactions.ExecBatchStatement;
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;
import com.djrapitops.plan.storage.database.transactions.Transaction; import com.djrapitops.plan.storage.database.transactions.Transaction;
import org.apache.commons.lang3.StringUtils;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
@ -111,7 +112,7 @@ public class StorePlayerTableResultTransaction extends Transaction {
statement.setString(2, playerUUID.toString()); statement.setString(2, playerUUID.toString());
for (int i = 0; i < maxColumnSize; i++) { for (int i = 0; i < maxColumnSize; i++) {
Object value = row[i]; Object value = row[i];
setStringOrNull(statement, 3 + i, value != null ? value.toString() : null); setStringOrNull(statement, 3 + i, value != null ? StringUtils.truncate(value.toString(), 250) : null);
} }
// Rest are set null if not 4 columns wide. // Rest are set null if not 4 columns wide.
for (int i = maxColumnSize; i < 4; i++) { for (int i = maxColumnSize; i < 4; i++) {

View File

@ -26,6 +26,7 @@ import com.djrapitops.plan.storage.database.transactions.ExecBatchStatement;
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;
import com.djrapitops.plan.storage.database.transactions.Transaction; import com.djrapitops.plan.storage.database.transactions.Transaction;
import org.apache.commons.lang3.StringUtils;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
@ -110,7 +111,7 @@ public class StoreServerTableResultTransaction extends Transaction {
statement.setString(2, serverUUID.toString()); statement.setString(2, serverUUID.toString());
for (int i = 0; i < maxColumnSize; i++) { for (int i = 0; i < maxColumnSize; i++) {
Object value = row[i]; Object value = row[i];
setStringOrNull(statement, 3 + i, value != null ? value.toString() : null); setStringOrNull(statement, 3 + i, value != null ? StringUtils.truncate(value.toString(), 250) : null);
} }
// Rest are set null if not 5 columns wide. // Rest are set null if not 5 columns wide.
for (int i = maxColumnSize; i < 5; i++) { for (int i = maxColumnSize; i < 5; i++) {

View File

@ -167,7 +167,8 @@ public abstract class SQLDB extends AbstractDatabase {
new IPAnonPatch(), new IPAnonPatch(),
new BadAFKThresholdValuePatch(), new BadAFKThresholdValuePatch(),
new DeleteIPHashesPatch(), new DeleteIPHashesPatch(),
new ExtensionShowInPlayersTablePatch() new ExtensionShowInPlayersTablePatch(),
new ExtensionTableRowValueLengthPatch()
}; };
} }

View File

@ -18,11 +18,13 @@ package com.djrapitops.plan.storage.database.queries.schema;
import com.djrapitops.plan.storage.database.queries.HasMoreThanZeroQueryStatement; import com.djrapitops.plan.storage.database.queries.HasMoreThanZeroQueryStatement;
import com.djrapitops.plan.storage.database.queries.Query; import com.djrapitops.plan.storage.database.queries.Query;
import com.djrapitops.plan.storage.database.queries.QueryStatement;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
import static com.djrapitops.plan.storage.database.sql.parsing.Sql.SELECT; import static com.djrapitops.plan.storage.database.sql.parsing.Sql.*;
/** /**
* Static method class for H2 Schema related queries. * Static method class for H2 Schema related queries.
@ -56,4 +58,23 @@ public class H2SchemaQueries {
} }
}; };
} }
public static Query<Integer> columnVarcharLength(String table, String column) {
String sql = SELECT + "CHARACTER_MAXIMUM_LENGTH" +
FROM + "INFORMATION_SCHEMA.COLUMNS " +
WHERE + "TABLE_NAME=? AND COLUMN_NAME=?";
return new QueryStatement<Integer>(sql) {
@Override
public void prepare(PreparedStatement statement) throws SQLException {
statement.setString(1, table);
statement.setString(2, column);
}
@Override
public Integer processResults(ResultSet set) throws SQLException {
return set.next() ? set.getInt("CHARACTER_MAXIMUM_LENGTH") : Integer.MAX_VALUE;
}
};
}
} }

View File

@ -109,6 +109,25 @@ public class MySQLSchemaQueries {
}; };
} }
public static Query<Integer> columnVarcharLength(String table, String column) {
String sql = SELECT + "CHARACTER_MAXIMUM_LENGTH" +
FROM + "information_schema.COLUMNS" +
WHERE + "TABLE_NAME=? AND COLUMN_NAME=? AND TABLE_SCHEMA=DATABASE()";
return new QueryStatement<Integer>(sql) {
@Override
public void prepare(PreparedStatement statement) throws SQLException {
statement.setString(1, table);
statement.setString(2, column);
}
@Override
public Integer processResults(ResultSet set) throws SQLException {
return set.next() ? set.getInt("CHARACTER_MAXIMUM_LENGTH") : Integer.MAX_VALUE;
}
};
}
/** /**
* Represents a FOREIGN KEY constraint in a MySQL database. * Represents a FOREIGN KEY constraint in a MySQL database.
* *

View File

@ -49,10 +49,10 @@ public class ExtensionPlayerTableValueTable {
return CreateTableParser.create(TABLE_NAME, dbType) return CreateTableParser.create(TABLE_NAME, dbType)
.column(ID, INT).primaryKey() .column(ID, INT).primaryKey()
.column(USER_UUID, Sql.varchar(36)).notNull() .column(USER_UUID, Sql.varchar(36)).notNull()
.column(VALUE_1, Sql.varchar(50)) .column(VALUE_1, Sql.varchar(250))
.column(VALUE_2, Sql.varchar(50)) .column(VALUE_2, Sql.varchar(250))
.column(VALUE_3, Sql.varchar(50)) .column(VALUE_3, Sql.varchar(250))
.column(VALUE_4, Sql.varchar(50)) .column(VALUE_4, Sql.varchar(250))
.column(TABLE_ID, INT).notNull() .column(TABLE_ID, INT).notNull()
.foreignKey(TABLE_ID, ExtensionTableProviderTable.TABLE_NAME, ExtensionPluginTable.ID) .foreignKey(TABLE_ID, ExtensionTableProviderTable.TABLE_NAME, ExtensionPluginTable.ID)
.build(); .build();

View File

@ -50,11 +50,11 @@ public class ExtensionServerTableValueTable {
return CreateTableParser.create(TABLE_NAME, dbType) return CreateTableParser.create(TABLE_NAME, dbType)
.column(ID, INT).primaryKey() .column(ID, INT).primaryKey()
.column(SERVER_UUID, Sql.varchar(36)).notNull() .column(SERVER_UUID, Sql.varchar(36)).notNull()
.column(VALUE_1, Sql.varchar(50)) .column(VALUE_1, Sql.varchar(250))
.column(VALUE_2, Sql.varchar(50)) .column(VALUE_2, Sql.varchar(250))
.column(VALUE_3, Sql.varchar(50)) .column(VALUE_3, Sql.varchar(250))
.column(VALUE_4, Sql.varchar(50)) .column(VALUE_4, Sql.varchar(250))
.column(VALUE_5, Sql.varchar(50)) .column(VALUE_5, Sql.varchar(250))
.column(TABLE_ID, INT).notNull() .column(TABLE_ID, INT).notNull()
.foreignKey(TABLE_ID, ExtensionTableProviderTable.TABLE_NAME, ExtensionPluginTable.ID) .foreignKey(TABLE_ID, ExtensionTableProviderTable.TABLE_NAME, ExtensionPluginTable.ID)
.build(); .build();

View File

@ -0,0 +1,68 @@
/*
* This file is part of Player Analytics (Plan).
*
* Plan is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License v3 as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Plan is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
*/
package com.djrapitops.plan.storage.database.transactions.patches;
import com.djrapitops.plan.storage.database.DBType;
import com.djrapitops.plan.storage.database.queries.schema.H2SchemaQueries;
import com.djrapitops.plan.storage.database.queries.schema.MySQLSchemaQueries;
import com.djrapitops.plan.storage.database.sql.parsing.Sql;
import com.djrapitops.plan.storage.database.sql.tables.ExtensionPlayerTableValueTable;
import com.djrapitops.plan.storage.database.sql.tables.ExtensionServerTableValueTable;
public class ExtensionTableRowValueLengthPatch extends Patch {
private String playerTable;
private String serverTable;
public ExtensionTableRowValueLengthPatch() {
playerTable = ExtensionPlayerTableValueTable.TABLE_NAME;
serverTable = ExtensionServerTableValueTable.TABLE_NAME;
}
@Override
public boolean hasBeenApplied() {
return dbType == DBType.SQLITE || // SQLite does not limit varchar lengths
(columnVarcharLength(playerTable, ExtensionPlayerTableValueTable.VALUE_4) >= 250
&& columnVarcharLength(serverTable, ExtensionServerTableValueTable.VALUE_5) >= 250);
}
private int columnVarcharLength(String table, String column) {
if (dbType == DBType.MYSQL) {
return query(MySQLSchemaQueries.columnVarcharLength(table, column));
} else {
return query(H2SchemaQueries.columnVarcharLength(table, column));
}
}
@Override
protected void applyPatch() {
increaseLength(playerTable, ExtensionPlayerTableValueTable.VALUE_1);
increaseLength(playerTable, ExtensionPlayerTableValueTable.VALUE_2);
increaseLength(playerTable, ExtensionPlayerTableValueTable.VALUE_3);
increaseLength(playerTable, ExtensionPlayerTableValueTable.VALUE_4);
increaseLength(serverTable, ExtensionServerTableValueTable.VALUE_1);
increaseLength(serverTable, ExtensionServerTableValueTable.VALUE_2);
increaseLength(serverTable, ExtensionServerTableValueTable.VALUE_3);
increaseLength(serverTable, ExtensionServerTableValueTable.VALUE_4);
increaseLength(serverTable, ExtensionServerTableValueTable.VALUE_5);
}
private void increaseLength(String table, String column) {
execute("ALTER TABLE " + table + " MODIFY " + column + " " + Sql.varchar(250));
}
}