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

Python Discussion :

SELECT * FROM


Sujet :

Python

  1. #1
    Invité
    Invité(e)
    Par défaut SELECT * FROM
    Bonjour à tous,

    J'applique une requête de recherche sur une table à 3 colonnes toutes aux format txt.
    Ces 3 colonnes sont exemple Nom Prénom Age que j'affiche dans des Entry widget.
    Je me sers de ces derniers pour entré la/les valeur(s) de recherche.

    J'obtient bien le résultat avec une seul variable.
    Dés que j'applique la recherche avec les deux variables alors que je rentre qu'une seul information, la variable var_HEDos fonctionne (en faite la dernière sur la ligne SELECT)
    Cette requête est dans le fichier B.py qui est appeler par la fonction searchDataBase() du fichier A.py


    Fichier A.py
    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
     
        # # Cherche enregistrement dans Table
        def searchDataBase():
            var_HENom = HENom.get()
            print(var_HENom)
     
            HEProp = txt_HEProp.get("1.0", "end-1c")            # Variable de la saisie du Widget Text
            var_HEProp = HEProp
            print(var_HEProp)
     
            var_HEDos = HEDos.get()
            print(var_HEDos)
            # Empty_TreeView()
     
            for rows in HE_DB_BackEnd.searchDataTable(var_HENom, var_HEDos):
        # #        HElist.insert('', 'end', text=i[0], values=(i[0], i[1], i[2], i[3]))
                 print("Index", rows[0], rows[1], rows[2], rows[3])

    Fichier B.py
    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
     
     
    # def searchDataTable(HE_Nom="", HE_Prop="", HE_Dosage=""):
    def searchDataTable(var_HENom, var_HEDos):
        print("var_HE_Nom", var_HENom)
        # print("var_HEProp", var_HEProp)
        print("var_HE_Dosage", var_HEDos)
        print("var_HENom", type(var_HENom))
        print("var_HEDos", type(var_HEDos))
     
        con = sqlite3.connect("HE.db")
        cur = con.cursor()
        # cur.execute("SELECT * FROM HE WHERE HE_Nom = ? OR HE_Dosage = ?", ('%' + str(var_HENom) + '%', '%' + str(var_HEDos) + '%',))
        cur.execute("SELECT * FROM HE WHERE HE_Nom = ? OR HE_Dosage = ?", (str(var_HENom),  str(var_HEDos),))
        rows = cur.fetchall()
        print("Nombre d'enregistrement(s) recherché(s)",len(rows))                                        # Nombre d'enregistrement
        for ii in rows:
            print("--------",ii)
    je n'arrive pas à trouver l'erreur d'écriture malgrès le lecture du Lien suivant
    merci pour votre aide
    Bien à vous

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 776
    Par défaut
    Salut,

    Votre requête semble correcte.

    Après comme on ne peut pas reproduire, difficile de dire d'où vient le soucis.

    Normalement, vous devez avoir testé le bon fonctionnement de vos fonctions d'accès à la base de données pour pouvoir vous y fier avant de l'utiliser.
    Sans cette précaution, en cas de problème, vous n'êtes sûr de rien et impossible de savoir où chercher.

    On peut bien sûr écrire un petit exemple pour illustrer que ces opérations fonctionnent.
    Ca ne dira pas pourquoi çà ne fonctionne pas chez vous, juste suggérer que le problème est "ailleurs".
    Et vous pouvez très bien l'écrire tout seul.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 851
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 851
    Billets dans le blog
    1
    Par défaut
    Bonjour

    Une requête SQL sur des colonnes de type string doit normalement encadrer la chaine cherchée entre quotes non ?
    Je pense que ça devrait être cur.execute("SELECT * FROM HE WHERE HE_Nom = '?' OR HE_Dosage = '?'", (str(var_HENom), str(var_HEDos),)).
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 776
    Par défaut
    Salut,

    Citation Envoyé par Sve@r Voir le message
    Une requête SQL sur des colonnes de type string doit normalement encadrer la chaine cherchée entre quotes non ?
    C'est une requête SQL mais cuisinée façon DB API.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Invité
    Invité(e)
    Par défaut
    voici les 4 fichiers, en pièces jointes, y compris la DB HE.DB.txt à renommer en HE.DB

    merci pour l'aide
    Fichiers attachés Fichiers attachés

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 776
    Par défaut
    Salut,

    Citation Envoyé par taratatasoleil Voir le message
    voici les 4 fichiers, en pièces jointes, y compris la DB HE.DB.txt à renommer en HE.DB
    Si vous n'avez pas le temps de réduire votre code pour qu'on puisse reproduire facilement le problème, ben, je n'ai pas plus de temps que vous.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Invité
    Invité(e)
    Par défaut
    Désolé, je ne savait pas qu'il fallait éliminer ce qui n'est pas concerné par le problème.
    voici les 4 nouveaux fichiers modifiés, en pièces jointes, y compris la DB HE.DB.txt à renommer en HE.DB

    merci de votre temps
    Fichiers attachés Fichiers attachés

  8. #8
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 776
    Par défaut
    Salut,

    Citation Envoyé par taratatasoleil Voir le message
    Désolé, je ne savait pas qu'il fallait éliminer ce qui n'est pas concerné par le problème.
    Bah, ce n'est pas un centre d'appel, juste un forum d'entre-aide non pour réparer des codes pourris mais pour essayer de devenir un meilleur programmeur Python.
    Donc déjà, il faut décrire le problème rencontré, puis donner les moyens de le reproduire facilement.
    Et si vous voulez montrez que vous avez un peu bossé dessus avant de demander de l'aide, çà veut dire que le code qui le reproduit se réduit à un seul fichier, quelques dizaines de lignes,...

    note: j'ai lancé votre application, je ne trouve rien d'anormal (après, il y a vos attentes mais je ne suis pas dans votre tête).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  9. #9
    Invité
    Invité(e)
    Par défaut
    J'applique une requête de recherche sur une table à 3 colonnes toutes aux format txt.
    Les 3 colonnes sont affichée dans des Entry widget.
    Je me sers de ces derniers pour entrer la/les valeur(s) de recherche.

    j'ai fais les test suivants :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
            cur.execute("SELECT * FROM HE WHERE HE_Nom=?", (txt_HENom.get(),))        # [OK - Fonctionne]
            cur.execute("SELECT * FROM HE WHERE HE_Nom= :W1", {"W1": txt_HENom.get()})
             cur.execute("SELECT * FROM HE WHERE HE_Prop=?", (HE_Prop,))               # [OK - Fonctionne]
             cur.execute("SELECT * FROM HE WHERE HE_Dosage=?", (txt_HEDos.get(),))       # [OK - Fonctionne]
     
            cur.execute("SELECT * FROM HE WHERE HE_Nom=? OR HE_Prop=?", (txt_HENom.get(), HE_Prop,))    # [OK - Fonctionne]
    et ceci non
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cur.execute("SELECT * FROM HE WHERE HE_Nom=? OR HE_Dosage=?", (txt_HENom.get(), txt_HEDos.get(),))
    dès que je mets HE_Dosage avec un autre, cela ne fonctionne pas. le problème vient de txt_HEDos.get()

    PS: je ne comprends pas votre virulence envers moi.
    Je fais recours au forum une fois épuisé toutes investigations et lectures théoriques et pratiques.
    Dernière modification par Invité ; 02/04/2020 à 19h42. Motif: Ajout des balises [CODE] mon code [/CODE] (bouton #)

  10. #10
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 776
    Par défaut
    Salut,

    Citation Envoyé par taratatasoleil Voir le message
    dès que je mets HE_Dosage avec un autre, cela ne fonctionne pas. le problème vient de txt_HEDos.get()
    çà ne fonctionne pas est un peu léger pour décrire ce qu'on obtient et en quoi c'est différent de ce qu'on attendait.

    txt_HEDos.get() est juste une chaine de caractères: montrer ce qu'elle contient en cas de problème plutôt que comment vous la récupérez serait plus instructif.

    PS: je ne comprends pas votre virulence envers moi.
    Je fais recours au forum une fois épuisé toutes investigations et lectures théoriques et pratiques.
    J'essaie juste de vous faire bosser plutôt que faire le boulot à votre place.
    notez qu'on n'a toujours pas de description du problème qui permette de savoir quoi regarder.
    Et comme je n'ai pas beaucoup de succès, je vais me taire pour voir si mes collègues arrivent à comprendre le problème et vous proposer une solution.
    Bon courage!

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  11. #11
    Invité
    Invité(e)
    Par défaut
    problème résolu...

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

Discussions similaires

  1. [COUNT] select ... from ... where count !
    Par tmcgrady dans le forum Langage SQL
    Réponses: 5
    Dernier message: 30/11/2007, 17h29
  2. SELECT * FROM (Transform...pivot...)... ???
    Par davidso dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 20/01/2006, 18h04
  3. Réponses: 5
    Dernier message: 31/10/2005, 13h25
  4. un SELECT FROM ????
    Par tarik75 dans le forum Langage SQL
    Réponses: 18
    Dernier message: 17/07/2005, 12h04
  5. Equivalent du Select * from ::Fn_Fonction()
    Par WOLO Laurent dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 09/07/2004, 09h48

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