ajout des parametres dans la base de donnée

This commit is contained in:
2026-03-10 16:23:20 +01:00
parent 6d7970970a
commit eb1ecdf405
2 changed files with 64 additions and 48 deletions

View File

@@ -1,80 +1,96 @@
package linea;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.*;
public class GestionnaireBDD {
private Connection conn = null;
private static final String DB_FILE = "linea_scores.db";
// On utilise une base de données SQLite, qui est un simple fichier.
private final String DB_URL = "jdbc:sqlite:linea.db";
public GestionnaireBDD() {
try {
// URL de connexion pour SQLite
String url = "jdbc:sqlite:" + DB_FILE;
// Établir la connexion
conn = DriverManager.getConnection(url);
// Le pilote JDBC pour SQLite doit être ajouté à votre projet.
Class.forName("org.sqlite.JDBC");
conn = DriverManager.getConnection(DB_URL);
System.out.println("Connexion à la base de données SQLite établie.");
// S'assurer que la table pour les scores existe
creerTableSiNecessaire();
} catch (SQLException e) {
System.err.println("Erreur de connexion à la base de données : " + e.getMessage());
System.out.println("Erreur de connexion à la BDD : " + e.getMessage());
} catch (ClassNotFoundException e) {
System.out.println("Le pilote JDBC SQLite n'a pas été trouvé. Veuillez l'ajouter à votre projet.");
}
}
private void creerTableSiNecessaire() {
String sql = "CREATE TABLE IF NOT EXISTS parties (\n"
+ " id INTEGER PRIMARY KEY AUTOINCREMENT,\n"
+ " duree_secondes INTEGER NOT NULL,\n"
+ " campagne_id INTEGER NOT NULL,\n"
+ " difficulte_id INTEGER NOT NULL,\n"
+ " score INTEGER NOT NULL,\n"
+ " date_partie TIMESTAMP DEFAULT CURRENT_TIMESTAMP\n"
+ ");";
// 'try-with-resources' assure que le Statement est bien fermé
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()) {
stmt.execute(sql);
// 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)");
// Table pour les scores des parties
stmt.execute("CREATE TABLE IF NOT EXISTS parties (" +
"id INTEGER PRIMARY KEY AUTOINCREMENT, " +
"duree INT, " +
"campagne_id INT, " +
"difficulte_id INT, " +
"score INT, " +
"date_partie TIMESTAMP DEFAULT CURRENT_TIMESTAMP)");
// 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);");
} catch (SQLException e) {
System.err.println("Erreur lors de la création de la table : " + e.getMessage());
System.out.println("Erreur lors de l'initialisation de la base de données : " + e.getMessage());
}
}
public void enregistrerPartie(int dureePartie, int idCampagne, int idDifficulte, int score) {
if (conn == null) {
System.err.println("Impossible d'enregistrer la partie : pas de connexion à la BDD.");
return;
}
String sql = "INSERT INTO parties(duree_secondes, campagne_id, difficulte_id, score) VALUES(?,?,?,?)";
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 = ?";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
pstmt.setInt(1, difficulteId);
ResultSet rs = pstmt.executeQuery();
if (rs.next()) {
params[0] = rs.getDouble("vitesse");
params[1] = rs.getDouble("pente");
}
} catch (SQLException e) {
System.out.println("Erreur lors de la récupération des paramètres de difficulté : " + e.getMessage());
}
return params;
}
public void enregistrerPartie(int dureePartie, int idCampagneActive, int difficulteActive, int score) {
String sql = "INSERT INTO parties(duree, campagne_id, difficulte_id, score) VALUES(?,?,?,?)";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
pstmt.setInt(1, dureePartie);
pstmt.setInt(2, idCampagne);
pstmt.setInt(3, idDifficulte);
pstmt.setInt(2, idCampagneActive);
pstmt.setInt(3, difficulteActive);
pstmt.setInt(4, score);
pstmt.executeUpdate();
System.out.println("Partie enregistrée avec succès ! Score : " + score);
System.out.println("Partie enregistrée avec succès.");
} catch (SQLException e) {
System.err.println("Erreur lors de l'enregistrement de la partie : " + e.getMessage());
System.out.println("Erreur lors de l'enregistrement de la partie : " + e.getMessage());
}
}
public void fermerConnexion() {
try {
if (conn != null && !conn.isClosed()) {
if (conn != null) {
conn.close();
System.out.println("Connexion à la base de données fermée.");
System.out.println("Connexion BDD fermée.");
}
} catch (SQLException ex) {
System.err.println("Erreur lors de la fermeture de la connexion BDD : " + ex.getMessage());
System.out.println(ex.getMessage());
}
}
}