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

Bases de données Discussion :

Tri avec QSqlQueryModel et QTableView


Sujet :

Bases de données

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 7
    Points : 4
    Points
    4
    Par défaut Tri avec QSqlQueryModel et QTableView
    Bonjour à tous,

    J'ai un petit soucis avec l'objet "QTableView". Le problème est que j'aimerai pouvoir activer le tri ("setSortingEnabled(true)") et que cela fonctionne .
    Avec un model de type "QSqlTableModel", je n'ai aucun problème par contre avec un model de type "QSqlQueryModel" le tri ne fonctionne pas et j'ai pourtant besoin de ce type puisque je fais une requête sur 3 tables. C'est pourquoi je me tourne vers vous afin que vous puissiez m'éclairer.
    D'avance merci.

  2. #2
    Membre expérimenté
    Avatar de FloMo
    Homme Profil pro
    Freelance iOS
    Inscrit en
    Juillet 2004
    Messages
    726
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Deux Sèvres (Poitou Charente)

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

    Informations forums :
    Inscription : Juillet 2004
    Messages : 726
    Points : 1 511
    Points
    1 511
    Par défaut
    Tu as une méthode à implémenter dans ton QSqlQueryModel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    void QAbstractItemModel::sort ( int column, Qt::SortOrder order = Qt::AscendingOrder )
    Elle va te permettre de mettre à jour ta requête.
    "Il est plus facile de décomposer un problème en ses éléments, forcément plus simples, que de le traiter en sa totalité." (R. Descartes)

    Freelance iOS

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 7
    Points : 4
    Points
    4
    Par défaut
    merci pour la réponse, je vais essayer ce soir.

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 7
    Points : 4
    Points
    4
    Par défaut
    J'ai un petit problème lors de la compilation ...
    Voici le code que je viens de mettre en place

    Model.h
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    class Model : public QSqlQueryModel
    {
        Q_OBJECT
     
        public:
            Model(QObject *parent = 0);
            virtual void sort(int column, Qt::SortOrder order);
    };
    Model.cpp
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Model::Model(QObject *parent) : QSqlQueryModel(parent)
    {
     
    }
     
    void Model::sort(int column, Qt::SortOrder order)
    {
        //appel de setQuery();
    }
    Si j'ai bien compris je dois créer la requête qui triera dans sort à l'aide des paramètres "column" et "order" et appeler setQuery() avec cette requête.

    Je n'ai pas encore réalisé "le tri" et j'essaye de compiler avant mais j'obtiens des erreurs:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    debug/Model.o: In function `_ZN5ModelC2EP7QObject':
    C:/Users/Olivier/Documents/MM/Model.cpp:4: undefined reference to `vtable for Model'
    debug/Model.o: In function `_ZN5ModelC1EP7QObject':
    C:/Users/Olivier/Documents/MM/Model.cpp:4: undefined reference to `vtable for Model'
    Je voudrais d'abord savoir si j'ai bien compris ce que je devais faire et si oui pourquoi j'ai cette erreur à la compilation.

    D'avance merci.

  5. #5
    Membre expérimenté
    Avatar de FloMo
    Homme Profil pro
    Freelance iOS
    Inscrit en
    Juillet 2004
    Messages
    726
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Deux Sèvres (Poitou Charente)

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

    Informations forums :
    Inscription : Juillet 2004
    Messages : 726
    Points : 1 511
    Points
    1 511
    Par défaut
    Enlève le "virtual" de la déclaration.

    Fais un make clean.
    Refais ton qmake et ton make.

    Je pense que le problème vient de là : ça arrive parfois.

    Sinon, comme dirait Mulder, la vérité est ailleurs...
    "Il est plus facile de décomposer un problème en ses éléments, forcément plus simples, que de le traiter en sa totalité." (R. Descartes)

    Freelance iOS

  6. #6
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 7
    Points : 4
    Points
    4
    Par défaut
    Merci beaucoup FloMo pour ton aide, j'ai réussi.
    Pour la compilation le make clean a réglé le problème.

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

Discussions similaires

  1. formule de calcul du TRI avec PL/SQL
    Par mongilotti dans le forum Algorithmes et structures de données
    Réponses: 15
    Dernier message: 30/07/2005, 20h23
  2. Pb de tri avec champs vide
    Par nesbla dans le forum Langage SQL
    Réponses: 2
    Dernier message: 01/06/2004, 17h42
  3. tri avec l'ordre UPDATE et incrementation d'une colonne
    Par Staron dans le forum Langage SQL
    Réponses: 3
    Dernier message: 17/02/2004, 08h48
  4. tri avec les champs vides en dernier
    Par r-zo dans le forum Requêtes
    Réponses: 11
    Dernier message: 03/09/2003, 13h40

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