changement segments et ligne
This commit is contained in:
@@ -28,7 +28,14 @@ public class GestionnaireBDD {
|
||||
stmt.execute("CREATE TABLE IF NOT EXISTS difficultes (" +
|
||||
"id_difficulte INT PRIMARY KEY, " +
|
||||
"vitesse REAL NOT NULL, " +
|
||||
"pente REAL NOT NULL)");
|
||||
"pente REAL NOT NULL, " +
|
||||
"segments INT NOT NULL DEFAULT 50)");
|
||||
|
||||
try {
|
||||
stmt.execute("ALTER TABLE difficultes ADD COLUMN segments INT NOT NULL DEFAULT 50");
|
||||
} catch (SQLException e) {
|
||||
// Ignorer si la colonne existe déjà
|
||||
}
|
||||
|
||||
// Table pour les scores des parties
|
||||
stmt.execute("CREATE TABLE IF NOT EXISTS parties (" +
|
||||
@@ -48,10 +55,10 @@ public class GestionnaireBDD {
|
||||
"mot_de_passe TEXT NOT NULL)");
|
||||
|
||||
// Insertion des valeurs de difficulté par défaut
|
||||
// L'instruction "INSERT OR IGNORE" est spécifique à SQLite et évite les doublons.
|
||||
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (1, 6, 20);");
|
||||
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (2, 7, 45);");
|
||||
stmt.execute("INSERT OR IGNORE INTO difficultes (id_difficulte, vitesse, pente) VALUES (3, 8, 70);");
|
||||
// On utilise INSERT OR REPLACE pour mettre à jour les valeurs si elles existent déjà
|
||||
stmt.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (1, 6, 20, 50);");
|
||||
stmt.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (2, 7, 45, 65);");
|
||||
stmt.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (3, 8, 60, 80);");
|
||||
|
||||
} catch (SQLException e) {
|
||||
System.out.println("Erreur lors de l'initialisation de la base de données : " + e.getMessage());
|
||||
@@ -100,8 +107,8 @@ public class GestionnaireBDD {
|
||||
}
|
||||
public double[] getParametresDifficulte(int difficulteId) {
|
||||
// Par défaut (si non trouvé), on retourne les valeurs pour la difficulté 1.
|
||||
double[] params = {6.0, 20.0};
|
||||
String sql = "SELECT vitesse, pente FROM difficultes WHERE id_difficulte = ?";
|
||||
double[] params = {6.0, 20.0, 50.0};
|
||||
String sql = "SELECT vitesse, pente, segments FROM difficultes WHERE id_difficulte = ?";
|
||||
|
||||
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
|
||||
pstmt.setInt(1, difficulteId);
|
||||
@@ -110,6 +117,7 @@ public class GestionnaireBDD {
|
||||
if (rs.next()) {
|
||||
params[0] = rs.getDouble("vitesse");
|
||||
params[1] = rs.getDouble("pente");
|
||||
params[2] = rs.getDouble("segments");
|
||||
}
|
||||
} catch (SQLException e) {
|
||||
System.out.println("Erreur lors de la récupération des paramètres de difficulté : " + e.getMessage());
|
||||
|
||||
Reference in New Issue
Block a user