update BDD difficulté
This commit is contained in:
@@ -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());
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user