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 :

Utilisation d'un curseur pour lire base SQLite


Sujet :

Android

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2012
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Octobre 2012
    Messages : 27
    Points : 22
    Points
    22
    Par défaut Utilisation d'un curseur pour lire base SQLite
    Bonjour,
    j'essaie de lire des lignes dans ma base SQLIte et j'ai un souci (là où je pensais que ça ne pouvait que marcher ).
    voici ma fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    	public List<TaskDetails> ConvertCursorToListObject(Cursor c) {
    		// TODO Auto-generated method stub
    		List<TaskDetails> liste = new ArrayList<TaskDetails>();
     
    		// Si la liste est vide
    		if (c.getCount() == 0)
    			return liste;
     
    		// position sur le premeir item
    		c.moveToFirst();
    		int test = c.getCount();
    		// Pour chaque item
    		do {
     
    			TaskDetails Tache = ConvertCursorToObject(c);
     
    			liste.add(Tache);
    		} while (c.moveToNext());
     
    		// Fermeture du curseur
    		c.close();
     
    		return liste;
    	}
    Quand il n'y a qu'un seul item dans le cursor tout roule je le récupère bien dans l'objet Tache.
    Quand il y a plusieurs items, le premier est récupéré dans l'objet Tache et au moment d'exécuter c.moveToNext() ça s'arrête.
    Il n'y a rien de spécial (en rouge) dans LogCat.
    Quand je regarde dans la fenêtre des variables le cursor contient bien tous les items.
    La seule chose qu'il se passe quand j'exécute sous debugger est que la fenêtre SQLiteQuery.class s'affiche et me dit source not found.
    J'imagine que si le source n'existait pas ça ne compilerai pas donc je suis perdu.

    Merci par avance

  2. #2
    Membre à l'essai
    Inscrit en
    Octobre 2012
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Octobre 2012
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    Désolé,
    j'avais fait n'importe quoi... A croire que j'avais picollé

  3. #3
    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
    Oui... la logique c'est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    boolean hasMore = cursor.moveToFirst();
    while (hasMore) {
       ... use cursor ...
       hasMore = cursor.moveToNext();
    }
    Je n'aime pas trop le "do/while" car il est très souvent plus compliqué à mettre en oeuvre sans erreur, et toujours remplaçable par un simple while.
    Exemple dans le code montré qui "foire" si il n'y a pas de donnée dans le curseur.
    N'oubliez pas de cliquer sur mais aussi sur si un commentaire vous a été utile !
    Et surtout

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Logiciel pour gérer bases SQLite
    Par antoinev2 dans le forum SQLite
    Réponses: 5
    Dernier message: 21/02/2015, 11h55
  2. Utilisation d'un curseur pour changer les données
    Par Julien698 dans le forum Langage SQL
    Réponses: 16
    Dernier message: 13/12/2013, 15h57
  3. [MySQL] utiliser systematiquement un fichier pour lire un repertoire
    Par solaris13 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/06/2012, 18h56
  4. Réponses: 6
    Dernier message: 18/03/2012, 19h36
  5. utilisation d'un curseur pour un insert
    Par caballero dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 27/06/2007, 09h21

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