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

Qt Discussion :

QTableView très lent


Sujet :

Qt

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2009
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 11
    Points : 15
    Points
    15
    Par défaut QTableView très lent
    Bonjour,

    Je fais une interface qui permet d’afficher tous les employés stockés dans une base de données SQL Server.
    Pour ceci, j’utilise un QTableView auquel je lie un QSqlTableModel. J’ai créé une vue dans la base de données qui représente la table à afficher.
    Mon problème est que l’affichage de la table est très lent, ainsi que quand j’essaye de redimensionner mon interface ou tout simplement de scroller dans celle-ci. Elle ne contient pourtant dans mon test que une dizaine de lignes.

    Voici le code en question :

    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
     
    tModelEmploye = new QSqlTableModel(this);
    tModelEmploye->setTable("AfficherEmploye");
    tModelEmploye->select();
    tModelEmploye->setHeaderData(0, Qt::Horizontal, tr("Identifiant"));
    tModelEmploye->setHeaderData(1, Qt::Horizontal, tr("Nom"));
    tModelEmploye->setHeaderData(2, Qt::Horizontal, tr("Prenom"));
    tModelEmploye->setHeaderData(3, Qt::Horizontal, tr("Date de naissance"));
    tModelEmploye->setHeaderData(4, Qt::Horizontal, tr("Salaire"));
    tModelEmploye->setHeaderData(5, Qt::Horizontal, tr("Adresse"));
     
    ui->tViewEmploye->setModel(tModelEmploye);
    ui->tViewEmploye->setSelectionBehavior(QAbstractItemView::SelectRows);
    ui->tViewEmploye->setEditTriggers(QAbstractItemView::NoEditTriggers);
    ui->tViewEmploye->resizeColumnsToContents();
     
    ui->tViewEmploye->horizontalHeader()->setSortIndicatorShown(true);
    ui->tViewEmploye->horizontalHeader()->setSortIndicator(0, Qt::AscendingOrder);
     
    connect(ui->tViewEmploye->horizontalHeader(), SIGNAL(sectionClicked(int)), ui->tViewEmploye, SLOT(sortByColumn(int)));
    Si quelqu’un sait de où vient cette lenteur et comment je pourrais améliorer cella…

    Merci d’avance.

  2. #2
    Responsable 2D/3D/Jeux


    Avatar de LittleWhite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2008
    Messages
    26 859
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 26 859
    Points : 218 580
    Points
    218 580
    Billets dans le blog
    120
    Par défaut
    Bonjour,

    Je ne vois pas d'erreur dans ce point, mais je me demande combien d'éléments essayer vous d'afficher.
    De plus, ni aurait il pas certaines connexions qui se font trop souvent (ou autre truc du genre)
    Vous souhaitez participer à la rubrique 2D/3D/Jeux ? Contactez-moi

    Ma page sur DVP
    Mon Portfolio

    Qui connaît l'erreur, connaît la solution.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 13
    Points : 25
    Points
    25
    Par défaut
    Je connais mal le model QSqlTableModel mais je m'apercois que la super classe QSqlQueryModel réimplémente canFetchMore() et fetchMore() si :

    Fetches more rows from a database. This only affects databases that don't report back the size of a query (see QSqlDriver::hasFeature()).
    Donc je serai toi, je dériverai mon QSqlTableModel et je réimplémenterai canFetchMore(), fetchMore() et rowCount().
    Pour se faire je ne saurai trop te conseiller de jeter un oeil sur le sample situé dans $QTDIR/examples/itemviews/fetchmore

  4. #4
    Membre à l'essai
    Inscrit en
    Avril 2009
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 11
    Points : 15
    Points
    15
    Par défaut
    Tout d’abord merci pour vos réponses.

    J’utilise pour finir un QTableWidget que je remplis moi-même avec tous se que j’ai besoin. Et là je n’ai plus de problème de lenteur dans mon interface.

    Je ne comprends pas bien pourquoi avec QTableView, même après qu’il ait été remplit, mon interface soit aussi lente lors du redimensionnement ou lorsque je scroll, alors que dans le test que je faisais, elle ne contenait que 10 lignes…

    Enfin sa marche bien avec QTableWidget. Je réessayerai peut être plus tard avec QTableView quand j’aurai plus de temps.

  5. #5
    Inactif  


    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    5 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Novembre 2008
    Messages : 5 288
    Points : 15 620
    Points
    15 620
    Par défaut
    Bonjour yoyo1811

    Pour information, QTableWidget est une QTableView. Donc le problème vient probablement de l'utilisation du modèle. Probablement un accès à la base trop lent ou trop répétitif.

    Dans les codes exemples, on retrouve souvent la ligne suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    model->setEditStrategy(QSqlTableModel::OnManualSubmit);
    Mais sinon, en effet ton code est relativement standard et ne devrait pas poser de problème.

Discussions similaires

  1. BDD sur réseau très très très lent...
    Par ericain dans le forum Access
    Réponses: 12
    Dernier message: 20/02/2015, 17h17
  2. Ouverture et fermeture de base très lent...
    Par Tofdelille dans le forum Installation
    Réponses: 6
    Dernier message: 19/09/2006, 18h51
  3. [Lomboz] Editeur jsp très lent
    Par lr dans le forum Eclipse Java
    Réponses: 10
    Dernier message: 29/01/2005, 19h43
  4. SQL Server trés lent
    Par arwen dans le forum MS SQL Server
    Réponses: 18
    Dernier message: 07/11/2003, 14h45

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