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

Langage SQL Discussion :

Requête SQL sur base mmssms android


Sujet :

Langage SQL

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Requête SQL sur base mmssms android
    Bonjour à tous,

    je me permets de venir vers vous dans le cadre d'une requête dont je ne trouve pas la solution.

    Il s'agit d'une db issue d'une extraction d'un terminal android, en l'occurence, la base mmssms.db
    Cette base comporte plusieurs table bien évidement mais seul trois table m'intéresse, pdu, part et addr.
    je souhaite extraire les données suivantes numéro de téléphone, date, chemin des pièces jointes, text et smiley.

    j'arrive bien à extraire par l'intermédiaire de 3 requêtes, les données avec un point commun qui est le champ mid de la table part.
    Voici mes requêtes :

    1ère requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT addr.address num_téléphone, datetime((pdu.date), 'unixepoch', 'localtime') date_heure, part._data chemin_pièces_jointes, pdu.msg_box envoyé1_reçu2, part.mid
    FROM pdu, part, addr
    WHERE pdu._id=part.mid AND pdu._id=addr.msg_id AND part._data IS NOT NULL AND addr.address!='insert-address-token'
    ORDER BY date DESC
    2nd requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT part.mid, part.text
    FROM part
    WHERE part.text IS NOT NULL AND part.ct='text/plain'
    3ème requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT part.mid, part.text
    FROM part
    WHERE part.text IS NOT NULL AND part.ct='application/smil'
    Dans mon idée, je souhaitais créer des tables temporaires pour chacune des requêtes et créer une requête "pointant" sur ces trois table temporaire pour ensuite faire afficher les champs "num_téléphone, date_heure, chemin _PJ, texte et smiley à partir de ces trois tables temporaires car la seules jonction découverte est le part.mid ( dans la table part, il existe 3 lignes par mms (1 pour le chemin des pièces jointes, une pour le text et une pour le smiley), toute ont nécessairement un part._id différents mais un part.mid identique.

    Je n'arrive pas à créer cette commande ou une perttant cette affichage.

    Pourriez vous m'aider s'il vous plait, merci.

    J'espère avoir été explicite dans ma demande.
    En tout cas merci pour vos réponses.

    PS : j'utilise pour cela l'addon "sqlite manager" de firefox pour lire ma base "mmssms.db"
    Cordialement

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 909
    Points
    38 909
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    Pourquoi ne pas directement faire la jointure sur les 3 tables via la colonne commune part.mid ?

  3. #3
    Membre expérimenté
    Homme Profil pro
    DBA SQL Server
    Inscrit en
    Octobre 2012
    Messages
    862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA SQL Server
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2012
    Messages : 862
    Points : 1 736
    Points
    1 736
    Par défaut
    Comme le dit escartefigue, fait des jointures, ce sera bien plus simple : A lire : http://sqlpro.developpez.com/cours/sqlaz/jointures/
    Ce que nous avons fait pour nous-même meurt avec nous, ce que nous avons fait pour les autres et le monde est immortel. Albert Pike

    http://www.datacrossroad.be

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 043
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut
    Bonjour,

    c'était bien parti avec la requête 1

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT addr.address num_téléphone, datetime((u.date), 'unixepoch', 'localtime') date_heure, p1._data chemin_pièces_jointes,
               u.msg_box envoyé1_reçu2   << manquerait pas une virgule 
    FROM pdu U LEFT JOIN  part P1 ON U._id=p1.mid AND p1.text IS NOT NULL AND p1.ct=???????   << ici il me manque de quoi faire la distinction
                     LEFT JOIN  part P2 ON U._id=p2.mid AND p2.text IS NOT NULL AND p2.ct='text/plain'      
                     LEFT JOIN  part P3 ON U._id=p3.mid AND p3.text IS NOT NULL AND p3.ct='application/smil'
                     LEFT JOIN ADDR ON U._id=addr.msg_id AND addr.address!='insert-address-token'
    ORDER BY u.date DESC
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Bonjour et merci pour vos réponses rapides.
    Absent pendant quelques jours, je viens de voir vos messages.
    J'ai par ailleurs trouvé une solution en créant des tables temporaires et en effectuant ma dernière requête sur les tables temporaires.
    Merci à tous.
    Cordialement

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

Discussions similaires

  1. requête SQL sur base access
    Par pppa1 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 04/04/2011, 18h21
  2. requête SQL sur base access
    Par pppa1 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 27/03/2011, 08h19
  3. requêtes SQL sur base MySQL
    Par khaled_dev dans le forum Requêtes
    Réponses: 1
    Dernier message: 16/01/2008, 21h27
  4. Requête SQL sur plusieurs bases
    Par tonyparker dans le forum Requêtes
    Réponses: 5
    Dernier message: 25/09/2007, 15h48

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