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

SharePoint .NET Discussion :

SPGridView alimenté par une large source de données - Problème de performance


Sujet :

SharePoint .NET

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 23
    Points : 12
    Points
    12
    Par défaut SPGridView alimenté par une large source de données - Problème de performance
    Bonjour à tous,

    Pour remplir ma GridView, je créé un DataTable comme suit:
    j'interroge une liste avec une SPQuery qui me retourne quelques 10000 lignes dans un objet SPListItemCollection.
    Ensuite, afin de récupérer la DataTable, j'execute la méthode GetDataTable appliqué sur mon SPListItemCollection. Cette instruction est très très gourmande car le DataTable contient les 10000 lignes.
    Or, mon SPGridView est paginé en page de 10 lignes, ce qui est donc inutile de récupérer l'ensemble des lignes alors que j'en affiche que 10 par 10 ...

    En me renseignant, j'ai fais connaissance de la propriété ListItemCollectionPosition. J'ai donc limité ma SPQuery à 10 éléments, j'interroge la liste, je conserve la propriété ListItemCollectionPosition que je réinjecte à la query pour visualiser la page suivante.

    Mais:

    1- je ne vois pas comment gérer le retour à la page précédente

    2- le tri natif du SPGridView, du coup, ne s'applique pas à l'ensemble de la liste mais juste au 10 éléments de la page (faut-il inclure le tri dans la spquery, dans ce cas, le tri n'est plus tellement natif...)

    Pourriez-vous m'éclairer svp ?

  2. #2
    Expert confirmé Avatar de Lapinpanda
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juin 2009
    Messages
    3 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Juin 2009
    Messages : 3 230
    Points : 4 913
    Points
    4 913
    Par défaut
    Il faut que tu utilise un objet ObjectDataSource (de mémoire)

    Qui te permettra de gérer le sorting, filtering, grouping, paging.


    Comme tu l'a dis si tu filtre ton SPQuery, le sorting ne marche que sur ta page courante. Tu va devoir alimenter 100% de ton grid avec tes 10K data.

Discussions similaires

  1. [WD14] Combo alimenter par une base de donnée
    Par darkterreur dans le forum WinDev
    Réponses: 4
    Dernier message: 25/11/2009, 15h16
  2. Formulaire alimenté par une base de données
    Par claire13 dans le forum Langage
    Réponses: 5
    Dernier message: 25/10/2007, 10h31
  3. [AJAX] lier deux listes déroulantes alimenté par une base de données (Mysql)
    Par arnaudperfect dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 23/04/2007, 01h06
  4. Réponses: 1
    Dernier message: 20/03/2007, 09h24
  5. Fusion alimentée par une bloc note
    Par Sabact dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 03/11/2006, 17h44

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