update BDD difficulté

This commit is contained in:
2026-03-25 13:07:41 +01:00
parent d792ad1a33
commit 4551f8bf62

View File

@@ -7,13 +7,19 @@ import java.util.List;
public class GestionnaireBDD { public class GestionnaireBDD {
private Connection conn = null; private Connection conn = null;
private Connection connDifficulte = null;
private final String DB_URL = "jdbc:sqlite:linea.db"; private final String DB_URL = "jdbc:sqlite:linea.db";
private final String DB_DIFFICULTE_URL = "jdbc:sqlite:difficultes.db";
public GestionnaireBDD() { public GestionnaireBDD() {
try { try {
Class.forName("org.sqlite.JDBC"); Class.forName("org.sqlite.JDBC");
conn = DriverManager.getConnection(DB_URL); conn = DriverManager.getConnection(DB_URL);
System.out.println("Connexion à la base de données SQLite établie."); System.out.println("Connexion à la base de données SQLite établie.");
connDifficulte = DriverManager.getConnection(DB_DIFFICULTE_URL);
System.out.println("Connexion à la base de données SQLite pour les difficultés établie.");
} catch (SQLException e) { } catch (SQLException e) {
System.out.println("Erreur de connexion à la BDD : " + e.getMessage()); System.out.println("Erreur de connexion à la BDD : " + e.getMessage());
} catch (ClassNotFoundException e) { } catch (ClassNotFoundException e) {
@@ -24,18 +30,6 @@ public class GestionnaireBDD {
public void initialiserBaseDeDonnees() { public void initialiserBaseDeDonnees() {
// Crée les tables si elles n'existent pas et insère les données de difficulté. // Crée les tables si elles n'existent pas et insère les données de difficulté.
try (Statement stmt = conn.createStatement()) { try (Statement stmt = conn.createStatement()) {
// Table pour les difficultés
stmt.execute("CREATE TABLE IF NOT EXISTS difficultes (" +
"id_difficulte INT PRIMARY KEY, " +
"vitesse 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 // Table pour les scores des parties
stmt.execute("CREATE TABLE IF NOT EXISTS parties (" + stmt.execute("CREATE TABLE IF NOT EXISTS parties (" +
@@ -54,11 +48,25 @@ public class GestionnaireBDD {
"identifiant TEXT UNIQUE NOT NULL, " + "identifiant TEXT UNIQUE NOT NULL, " +
"mot_de_passe TEXT NOT NULL)"); "mot_de_passe TEXT NOT NULL)");
} catch (SQLException e) {
System.out.println("Erreur lors de l'initialisation de la base de données principale : " + e.getMessage());
}
try (Statement stmtDiff = connDifficulte.createStatement()) {
stmtDiff.execute("CREATE TABLE IF NOT EXISTS difficultes (" +
"id_difficulte INT PRIMARY KEY, " +
"vitesse REAL NOT NULL, " +
"pente REAL NOT NULL, " +
"segments INT NOT NULL DEFAULT 50)");
try {
stmtDiff.execute("ALTER TABLE difficultes ADD COLUMN segments INT NOT NULL DEFAULT 50");
} catch (SQLException e) {
// Ignorer si la colonne existe déjà
}
// Insertion des valeurs de difficulté par défaut // Insertion des valeurs de difficulté par défaut
// On utilise INSERT OR REPLACE pour mettre à jour les valeurs si elles existent déjà // 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, 35);"); stmtDiff.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (1, 6, 20, 35);");
stmt.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (2, 7, 45, 50);"); stmtDiff.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (2, 7, 45, 50);");
stmt.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (3, 8, 60, 85);"); stmtDiff.execute("INSERT OR REPLACE INTO difficultes (id_difficulte, vitesse, pente, segments) VALUES (3, 8, 60, 85);");
} catch (SQLException e) { } catch (SQLException e) {
System.out.println("Erreur lors de l'initialisation de la base de données : " + e.getMessage()); System.out.println("Erreur lors de l'initialisation de la base de données : " + e.getMessage());
@@ -110,7 +118,7 @@ public class GestionnaireBDD {
double[] params = {6.0, 20.0, 50.0}; double[] params = {6.0, 20.0, 50.0};
String sql = "SELECT vitesse, pente, segments FROM difficultes WHERE id_difficulte = ?"; String sql = "SELECT vitesse, pente, segments FROM difficultes WHERE id_difficulte = ?";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) { try (PreparedStatement pstmt = connDifficulte.prepareStatement(sql)) {
pstmt.setInt(1, difficulteId); pstmt.setInt(1, difficulteId);
ResultSet rs = pstmt.executeQuery(); ResultSet rs = pstmt.executeQuery();
@@ -201,6 +209,10 @@ public class GestionnaireBDD {
conn.close(); conn.close();
System.out.println("Connexion BDD fermée."); System.out.println("Connexion BDD fermée.");
} }
if (connDifficulte != null) {
connDifficulte.close();
System.out.println("Connexion BDD difficultés fermée.");
}
} catch (SQLException ex) { } catch (SQLException ex) {
System.out.println(ex.getMessage()); System.out.println(ex.getMessage());
} }