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

Linq Discussion :

LINQ-to-Entities lent avec la pagination


Sujet :

Linq

  1. #1
    Membre extrêmement actif
    Avatar de kedare
    Homme Profil pro
    SRE
    Inscrit en
    Juillet 2005
    Messages
    1 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Espagne

    Informations professionnelles :
    Activité : SRE

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 549
    Par défaut LINQ-to-Entities lent avec la pagination
    Hello,
    J'ai un petit problème, j'ai un site interne qui utiliser LINQ-to-Entities avec ASP.NET MVC 2, j'utilise ce code pour mon controleur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
        public ActionResult Index(int page = 0)
        {
            IronViperEntities db = new IronViperEntities();
            db.Connection.Open();
            DbTransaction transaction = db.Connection.BeginTransaction(IsolationLevel.ReadUncommitted);
            var messages = (from globalView in db.GlobalViews orderby globalView.MessageId descending select globalView).Skip(page*perPage).Take(perPage);
            transaction.Commit();
            db.Connection.Close();
            ViewData["page"] = page;
            ViewData["messages"] = messages;
            return View();
        }
    Ca fonctionne, mais plus je vais sur des pages loin, plus c'est lent, genre la page 2 met 700ms (90% de latence ici), c'est plus dans les 70ms en local, alors que la page 6354 met plus de 4 secondes...

    La transaction est obligatoire pour ne pas tomber sur des deadlocks (car une autre application remplis la base de données en même temps)
    La vue utilisé contient pour le moment 1 290 196 lignes (ça augmente...)

    J'utilise ASP.NET MVC 2, IIS7.5, SQL SERVER 2008 R2 Express Edition, Windows Server 2008 R2 Enterprise Edition.

    Comment faire pour optimiser ça ?
    Merci

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 18
    Par défaut
    Salut,

    Peux-tu poster la requête SQL générée par ton appel LINQ ?

  3. #3
    Membre extrêmement actif
    Avatar de kedare
    Homme Profil pro
    SRE
    Inscrit en
    Juillet 2005
    Messages
    1 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Espagne

    Informations professionnelles :
    Activité : SRE

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 549
    Par défaut
    Comment la voir sachant que SQL Profiler n'est pas disponible avec l'édition Express ?

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    18
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 18
    Par défaut
    Récupère ton objet DataContext, et assigne à sa propriété Log un flux : un fichier, un StringWriter, n'importe quoi d'autre, cela devrait marcher...

  5. #5
    Membre extrêmement actif
    Avatar de kedare
    Homme Profil pro
    SRE
    Inscrit en
    Juillet 2005
    Messages
    1 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Espagne

    Informations professionnelles :
    Activité : SRE

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 549
    Par défaut
    C'est récupérable via un breakpoint si non ?

    Bon, j'ai testé, voila un exemple de requete :
    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
    21
    22
    23
    SELECT TOP (100) 
    [Extent1].[MessageId] AS [MessageId], 
    [Extent1].[MessageUuid] AS [MessageUuid], 
    [Extent1].[MessageData] AS [MessageData], 
    [Extent1].[MessagePostDate] AS [MessagePostDate], 
    [Extent1].[ChannelName] AS [ChannelName], 
    [Extent1].[UserName] AS [UserName], 
    [Extent1].[UserUuid] AS [UserUuid], 
    [Extent1].[ChannelUuid] AS [ChannelUuid]
    FROM ( SELECT [Extent1].[MessageId] AS [MessageId], [Extent1].[MessageUuid] AS [MessageUuid], [Extent1].[MessageData] AS [MessageData], [Extent1].[MessagePostDate] AS [MessagePostDate], [Extent1].[ChannelName] AS [ChannelName], [Extent1].[UserName] AS [UserName], [Extent1].[UserUuid] AS [UserUuid], [Extent1].[ChannelUuid] AS [ChannelUuid], row_number() OVER (ORDER BY [Extent1].[MessageId] DESC) AS [row_number]
    	FROM (SELECT 
          [GlobalView].[MessageId] AS [MessageId], 
          [GlobalView].[MessageUuid] AS [MessageUuid], 
          [GlobalView].[MessageData] AS [MessageData], 
          [GlobalView].[MessagePostDate] AS [MessagePostDate], 
          [GlobalView].[ChannelName] AS [ChannelName], 
          [GlobalView].[UserName] AS [UserName], 
          [GlobalView].[UserUuid] AS [UserUuid], 
          [GlobalView].[ChannelUuid] AS [ChannelUuid]
          FROM [dbo].[GlobalView] AS [GlobalView]) AS [Extent1]
    )  AS [Extent1]
    WHERE [Extent1].[row_number] > 656700
    ORDER BY [Extent1].[MessageId] DESC

  6. #6
    Membre éclairé Avatar de bellak
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2008
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Juillet 2008
    Messages : 325
    Par défaut
    j'avais deja ce probleme , j'ai utilisé le using (ca garantie le dispose) et ca ma resolu le probleme , mais je ne sais pas si c'est la bonne solution pour ton probleme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    using (IronViperEntities db = new IronViperEntities ())
    {
       DbTransaction transaction = db.Connection.BeginTransaction(IsolationLevel.ReadUncommitted);
       var messages = (from globalView in db.GlobalViews orderby globalView.MessageId descending select globalView).Skip(page*perPage).Take(perPage);
       transaction.Commit();
       ViewData["page"] = page;
       ViewData["messages"] = messages;
       return View();
    }

Discussions similaires

  1. Problème avec Linq to Entities!
    Par MicaelFelix dans le forum Linq
    Réponses: 4
    Dernier message: 28/12/2009, 18h28
  2. [Entity Framework] Insertion de donnée avec LINQ to Entities
    Par Leelith dans le forum Framework .NET
    Réponses: 15
    Dernier message: 05/11/2009, 23h56
  3. Réponses: 3
    Dernier message: 09/06/2009, 11h08
  4. Réponses: 6
    Dernier message: 14/05/2009, 12h01
  5. Réponses: 0
    Dernier message: 29/04/2009, 17h35

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