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 :

SQLite supprimer données dupliquées


Sujet :

Android

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Cisco
    Inscrit en
    Juillet 2012
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Cisco
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2012
    Messages : 71
    Par défaut SQLite supprimer données dupliquées
    Bonjour,

    J'ai la Tbale suivante: table_news contenant ces champs:

    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
     ROWID = INTEGER PRIMARY KEY AUTOINCREMENT 
     
        ID = TEXT NOT NULL 
     
        CONTENT = TEXT NOT NULL
     
        ZONE TEXT = NOT NULL 
     
        AREA TEXT = NOT NULL
     
        TITLE TEXT = NOT NULL
     
        DATE TEXT = NOT NULL
     
        AUTHOR TEXT = NOT NULL
    Elle est remplit comme ceci:

    1st Row:

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     ROWID ==> 1
     
        ID ==> "5"
     
        CONTENT ==> "Discover New York."
     
        ZONE ==> "New York"
     
        AREA ==> "New York"
     
        TITLE ==> "Let's discover the world."
     
        DATE ==> "2012-07-04"     
     
        AUTHOR ==> "Henry Brakman"
     
    2nd Row (same but with ROWID field setted to 2):
     
     
     
        ROWID ==> 2
     
        ID ==> "5"
     
        CONTENT ==> "Discover New York."
     
        ZONE ==> "New York"
     
        AREA ==> "New York"
     
        TITLE ==> "Let's discover the world."
     
        DATE ==> "2012-07-04"     
     
        AUTHOR ==> "Henry Brakman"
    Je veux faire un sqlstatement qui va me supprimer les donnees redondantes (qui ont le meme ID par exemple).

    J'ai essaye cela mais ca ne marche pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public SQLiteStatement removeSameContentNews()
    	{
    		return bdd.compileStatement("DELETE FROM table_news WHERE ROWID NOT IN (SELECT MIN( ROWID) FROM table_news GROUP BY ID, CONTENT, ZONE, AREA, TITLE, DATE, AUTHOR)");
    	}
    Merci de m'aider les amis.

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    757
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 757
    Par défaut
    Pourquoi ne pas éradiquer le problème à sa source ?
    Je veux dire par là, pourquoi n'as tu pas mis une contrainte d'unicité sur l'ID ?

  3. #3
    Membre confirmé
    Homme Profil pro
    Cisco
    Inscrit en
    Juillet 2012
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Cisco
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2012
    Messages : 71
    Par défaut
    Comment faire ?? ca m'interesse !

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    757
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 757
    Par défaut
    Voilà le schéma

    En gros, je te conseille d'utiliser le mot clé PRIMARY KEY

  5. #5
    Membre confirmé
    Homme Profil pro
    Cisco
    Inscrit en
    Juillet 2012
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Cisco
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2012
    Messages : 71
    Par défaut
    Je ne comprend rien a ces schema,

    voici la requete de ma creation de table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    private static final String CREATE_TABLE_NEWS = "CREATE TABLE "+ TABLE_NEWS + " (" + COLUMN_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COL_ID + " TEXT NOT NULL, "+ COL_CONTENT +" TEXT NOT NULL, "+ COL_ZONE + " TEXT NOT NULL, "+ 
    	COL_AREA + " TEXT NOT NULL, "+ COL_TITLE + " TEXT NOT NULL, "+ COL_DATE + " TEXT NOT NULL, " + COL_AUTHOR +" TEXT NOT NULL);";
    Que dois je modifier pour eviter la redondance et creer l'unicite sur le champs ID?

  6. #6
    Membre émérite
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    757
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 757
    Par défaut
    Ben en fait il y a quelque chose qui m'échappe dans ta structure de données. A quoi correspond la champ ROWID ?
    Celui ci est déjà unique alors pourquoi vouloir rajouter un champ ID ?

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 26/01/2009, 10h56
  2. ajouter données sans supprimer données existantes
    Par grimat dans le forum Débuter
    Réponses: 1
    Dernier message: 04/01/2009, 21h42
  3. Réponses: 1
    Dernier message: 04/01/2009, 17h41
  4. ADO Excel, Supprimer Données dans Fichier Fermé
    Par vaucluseimmo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/08/2008, 19h20
  5. methodologie pour Supprimer données dans base de données
    Par elkhy dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 26/04/2006, 18h30

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