IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

Récupérer des données de ma base de données SQLite


Sujet :

Android

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Juillet 2013
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Récupérer des données de ma base de données SQLite
    j'ai crée une base de données, elle contient un tableau nommé TABLE_CATEGORY qui est formé par 3 colonnes :[*][id_category,category_name,image]
    Dans mon application Android je veux afficher les noms de ces catégories dans des TextView
    J'ai crée une méthode, mais elle ne fonctionne pas, je ne sais pas ou est le probléme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     public String getCategoryName(int i)
       {
    	   String selectQuery ="SELECT " + COL_CATEGORY_NAME + "FROM " +
    			    TABLE_CATEGORY + " WHERE " + COL_ID_CATEGORY +" = '" +i +"')";
     
    	   database=DBHelper.getWritableDatabase();
    	   Cursor cursor = database.rawQuery(selectQuery, null);
     
    	   return cursor.toString();
        }

  2. #2
    Expert éminent

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    4 253
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2007
    Messages : 4 253
    Points : 7 618
    Points
    7 618
    Billets dans le blog
    3
    Par défaut
    cursor.toString() probablement va renvoyer le 'nom' du cursor, et pas le contenu d'une des colonnes du cursor:

    D'abord, se rendre sur la première ligne, et si elle existe, demander la valeur de la première colonne.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    public String getCategoryName(int i)
    {
    String selectQuery ="SELECT " + COL_CATEGORY_NAME + "FROM " +
    TABLE_CATEGORY + " WHERE " + COL_ID_CATEGORY +" = '" +i +"')";
     
    database=DBHelper.getWritableDatabase();
    Cursor cursor = database.rawQuery(selectQuery, null);
     
    return (cursor.moveToFirst()) ? cursor.getString(0) : null;
    }
    Maintenant il faut aussi:
    * Fermer le cursor.
    * Utiliser les "prepared" statement de SQL:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    private static final String SQL_CATEGORY_NAME =
       "SELECT " + COL_CATEGORY_NAME + "FROM " + TABLE_CATEGORY + " WHERE " + COL_ID_CATEGORY +" = ?";
     
    public String getCategoryName(int i)
    {
        Cursor cursor = null;
        try {
             database=DBHelper.getWritableDatabase();
             cursor = database.rawQuery(SQL_CATEGORY_NAME , new String[] { Integer.toString(i) } );
             return (cursor.moveToFirst()) ? cursor.getString(0) : null;
        } finally {
             if (cursor != null) cursor.close();
        }
    }
    On remarquera:
    1. La construction de la requete SQL en dehors de la fonction (évite de la refaire à coups de StringBuilder à chaque appel de la fonction).
    2. Utilisation de query "paramétrée" (le ?) et les paramètres associés dans l'appel => utilisation de prepared statement, et souvent "cache" de ceux-ci.
    3. Utilisation de try / finally pour fermer en toute circonstance le cursor.

    Par contre, il me semble qu'il faille faire de même (close()) sur la database obtenue par getWritableDatabase() (en tout cas, à un moment il faudra la fermer).
    N'oubliez pas de cliquer sur mais aussi sur si un commentaire vous a été utile !
    Et surtout

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/02/2015, 15h48
  2. Récupérer des enregistrements de ma base de données
    Par cid5420 dans le forum Langage
    Réponses: 9
    Dernier message: 23/05/2014, 16h31
  3. [Débuter] Récupérer des informations d'une base de données SQL
    Par takago dans le forum Qt Creator
    Réponses: 1
    Dernier message: 02/12/2013, 17h24
  4. récupérer des valeurs de la base de donnée
    Par marwa580 dans le forum VB.NET
    Réponses: 2
    Dernier message: 17/05/2010, 22h43
  5. [MySQL] je cherche une aide pour récupérer des champs d'une base de donnée
    Par maya24 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 23/09/2007, 12h14

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo