diff --git a/src/linea/GestionnaireBDD.java b/src/linea/GestionnaireBDD.java index 75d5e33..812f575 100644 --- a/src/linea/GestionnaireBDD.java +++ b/src/linea/GestionnaireBDD.java @@ -7,13 +7,19 @@ import java.util.List; public class GestionnaireBDD { private Connection conn = null; + private Connection connDifficulte = null; private final String DB_URL = "jdbc:sqlite:linea.db"; + private final String DB_DIFFICULTE_URL = "jdbc:sqlite:difficultes.db"; + public GestionnaireBDD() { try { Class.forName("org.sqlite.JDBC"); conn = DriverManager.getConnection(DB_URL); 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) { System.out.println("Erreur de connexion à la BDD : " + e.getMessage()); } catch (ClassNotFoundException e) { @@ -24,18 +30,6 @@ public class GestionnaireBDD { public void initialiserBaseDeDonnees() { // Crée les tables si elles n'existent pas et insère les données de difficulté. 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 stmt.execute("CREATE TABLE IF NOT EXISTS parties (" + @@ -54,11 +48,25 @@ public class GestionnaireBDD { "identifiant TEXT UNIQUE 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 // 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);"); - stmt.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 (1, 6, 20, 35);"); + stmtDiff.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 (3, 8, 60, 85);"); } catch (SQLException e) { 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}; 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); ResultSet rs = pstmt.executeQuery(); @@ -201,6 +209,10 @@ public class GestionnaireBDD { conn.close(); System.out.println("Connexion BDD fermée."); } + if (connDifficulte != null) { + connDifficulte.close(); + System.out.println("Connexion BDD difficultés fermée."); + } } catch (SQLException ex) { System.out.println(ex.getMessage()); }