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

PyQt Python Discussion :

Filtre partiel de recherche [QtSql]


Sujet :

PyQt Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Billets dans le blog
    15
    Par défaut Filtre partiel de recherche


    Imaginons que dans une table nommée test d'une base de données quelconques j'ai les entrées suivantes :

    - entrée n°1 : id : 1 ; val : '12345" ; com : "test1"
    - entrée n°2 : id : 2 ; val : '23456" ; com : "test2"
    - entrée n°3 : id : 3 ; val : '45679" ; com : "test3"


    Je n'ai rien trouvé de base dans Qt Sql permettant de filtrer toutes les entrées dont val contient 34. Est-ce que je suis passé à coté de quelques choses ?

    Si effectivement rien n'existe cela risque de signifier qu'il va me falloir passer par du Regex : soit directement dans la requête Sql, avec sûrement des adaptations, soit en important toute la base sous forme de liste de liste et en filtrant après chaque sous-liste... à voir ce qui sera le plus performant en termes de rapidité d'exécution.

    Pour le moment pas besoin de vous casser la tête à trouver une solution en Regex... j'aimerai juste savoir si je passe à coté de quelques choses de "natif".

    D'avance merci à tous.

    J
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  2. #2
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Je n'ai pas le temps de chercher tout de suite, mais il me semble que ça existe dans les fonctions SQL. Regarde dans la doc de sqlite3 qui est assez claire: http://www.sqlite.org/lang.html

    Si tu n'as pas trouvé cet après-midi, je creuserai un peu. J'ai déjà fait pas mal de choses dans ce domaine (y compris des recherches de mots "similaires", avec ratio de similitude, dans une base).

  3. #3
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Billets dans le blog
    15
    Par défaut
    Re,

    Merci Tyrtamos. Je n'ai pas du tout pensé à regarder de ce coté. Sachant que QSqlTableModel hérite de QSqlQueryModel on peut en effet passé des "vraies" commandes Sql ce qui donne à priori dans mon cas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    model = QtSql.QSqlTableModel()
    model.setQuery(QtSql.QSqlQuery("SELECT * FROM test WHERE val REGEXP '.*34.*'"))
    model.select()
    Malheureusement cela ne me renvoie aucune entrée.

    J'ai testé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    model = QtSql.QSqlTableModel()
    model.setQuery(QtSql.QSqlQuery("SELECT * FROM test WHERE val LIKE '12345'"))
    model.select()
    et là j'ai bien quelque chose.

    Je continue à creuser car cela vient sûrement de ma REGEX (c'est pour ça que je voulais éviter ça ), mais si jamais tu vois une grosse erreur de ma part hésite pas.
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  4. #4
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Essaie ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select *
    from test
    where test.val like "%34%"
    En fait, like fait une recherche de type "wilcard", mais avec d'autres caractères: '%' au lieu de '*', et '_' au lieu de '?'. Voir ici d'autres subtilités: http://www.tutorialspoint.com/sqlite...ike_clause.htm.

  5. #5
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Billets dans le blog
    15
    Par défaut
    Nikel, mais pas besoin du test.valà priori.

    Par contre c'est étrange que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT * FROM test WHERE val REGEXP '.*34.*'"
    ne fonctionne pas...la REGEX est bien bonne pourtant, non ?
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  6. #6
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par Jiyuu Voir le message
    Par contre c'est étrange que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT * FROM test WHERE val REGEXP '.*34.*'"
    ne fonctionne pas...la REGEX est bien bonne pourtant, non ?
    Désolé, je ne peux pas essayer: REGEXP n'est pas implanté dans sqlite3.

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

Discussions similaires

  1. [XL-2010] Macro filtre élaboré probleme recherche
    Par exile69 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 26/09/2014, 10h19
  2. filtre partiel ds une table ado
    Par chiheb79 dans le forum Bases de données
    Réponses: 8
    Dernier message: 04/11/2009, 15h37
  3. Réponses: 6
    Dernier message: 18/06/2008, 15h49
  4. critere de filtre et de recherche commun
    Par alsimbad dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/06/2007, 16h23

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