Donnez votre avis

Connexion à une base de données access

Posez votre question
J'ai remarqué que cette question est posée fréquemment sur le forum. Alors voilà une classe MSAccessBase qui fournit une interface de connexion et d'émission de requêtes vers toute base Access..

Il n'est pas nécessaire de créer un compte ODBC pour utiliser cette classe..


/*
*Classe : MSAccessBase
*@author : Chatbour
*@date : 21 Octobre 2008
*/

import java.sql.*;

public class MSAccessBase {

    // Chemin de la base
    private String path;

    // Nom d'utilisateur
    private String user;

    // Mot de passe
    private String password;

    // Connection vers la base
    private Connection connection;


    /* Constructeur */
    public MSAccessBase(String path, String user, String password) {
        this.path = path;
        this.user = user;
        this.password = password;
    }


    /*
    *Connection à la base
    *@return : true si la connexion est réussie, false si échouée
    */
    public boolean connect() {
        try {
            // Chargement du driver ODBC
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            
            // Connexion à la base
            String connectionString = "jdbc:odbc:DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" + path;
            connection = DriverManager.getConnection(connectionString, user, password);
        }
        catch (ClassNotFoundException e) {
            System.out.println("Problème avec le driver ODBC");
            return false;
        }
        catch (SQLException e) {
            System.out.println("Impossible de se connecter à la base");
            return false;
        }
        return true;
    }


    /*
    *Déconnexion de la base
    *@return : true si la déconnexion est réussie, false sinon
    */
    public boolean disconnect() {
        try {
            connection.close();
            return true;
        }
        catch (SQLException e) {
            return false;
        }
    }

    /*
    *Envoi d'une requête de sélection
    *@param : sql
    *@return : result
    */
    public ResultSet SQLSelect(String sql) throws SQLException {
        Statement statement = null;
        ResultSet result = null;
        try {
            statement = connection.createStatement();
            result = statement.executeQuery(sql);
            return result;
        }
        catch (SQLException e) {
            result.close();
            statement.close();
            return null;
        }
    }

    /*
    *Envoi d'une requête de mise à jour (insert, update, delete)
    *@param : sql
    */
    public void SQLUpdate(String sql) throws SQLException {
        Statement statement = null;
        try {
            statement = connection.createStatement();
            statement.executeUpdate(sql);
        }
        catch (SQLException e) {
            
        }
    }
}

Publié par Chatbour. Dernière mise à jour le 3 septembre 2013 à 17:08 par BunoCS.

Ce document intitulé «  Connexion à une base de données access  » issu de CodeS-SourceS (https://codes-sources.commentcamarche.net/) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.

Ajouter un commentaire

Commentaires

Commenter la réponse de Chatbour