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

Framework .NET Discussion :

Linq, type anonyme et redondance


Sujet :

Framework .NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite Avatar de neptune
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2003
    Messages : 835
    Par défaut Linq, type anonyme et redondance
    Bonjour à tous,

    Encore moi sur Linq ;-)

    Je créé un type anonyme et j'aimerais optimizer. Je suppose que je ne m'y prend pas de la meilleure manière et j'aimerais corriger cela au plus vite.

    Voici le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    var results = from f in DataContext.Forums
    			  select new
    			  {
    				  f.Name,
    				  NumberOfTopic = f.Messages.Where(m => m.Topic == null).Count(),
    				  NumberOfMessage = f.Messages.Count(),
    				  LastMessageDate = f.Messages.OrderBy(m => m.CreationDate).ThenBy(m => m.Id).FirstOrDefault().CreationDate,
    				  LastMessageTitle = f.Messages.OrderBy(m => m.CreationDate).ThenBy(m => m.Id).FirstOrDefault().Title
    			  };
     
    return results;
    Et evidement, cela génère un sql avec une requete doublon:
    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
    24
    25
    26
    SELECT [t0].[Name], (
        SELECT COUNT(*)
        FROM [dbo].[Messages] AS [t1]
        WHERE ([t1].[TopicId] IS NULL) AND ([t1].[ForumId] = [t0].[Id])
        ) AS [NumberOfTopic], (
        SELECT COUNT(*)
        FROM [dbo].[Messages] AS [t2]
        WHERE [t2].[ForumId] = [t0].[Id]
        ) AS [NumberOfMessage], (
        SELECT [t4].[CreationDate]
        FROM (
            SELECT TOP (1) [t3].[CreationDate]
            FROM [dbo].[Messages] AS [t3]
            WHERE [t3].[ForumId] = [t0].[Id]
            ORDER BY [t3].[CreationDate], [t3].[Id]
            ) AS [t4]
        ) AS [LastMessageDate], (
        SELECT [t6].[Title]
        FROM (
            SELECT TOP (1) [t5].[Title]
            FROM [dbo].[Messages] AS [t5]
            WHERE [t5].[ForumId] = [t0].[Id]
            ORDER BY [t5].[CreationDate], [t5].[Id]
            ) AS [t6]
        ) AS [LastMessageTitle]
    FROM [dbo].[Forums] AS [t0]
    Comment modifier cela pour avoir un objet intermédiaire "Message" pour éviter de faire deux fois la même requete?

    Merci à vous!

  2. #2
    Rédacteur
    Avatar de The_badger_man
    Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2005
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 745
    Par défaut
    Citation Envoyé par neptune Voir le message
    Encore moi sur Linq ;-)
    Encore toi et ton forum

    Essaye un truc dans le genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    var results = from f in DataContext.Forums
                  let msg = f.Messages.OrderBy(m => m.CreationDate).ThenBy(m => m.Id).FirstOrDefault()
                  select new
                  {
                      f.Name,
                      NumberOfTopic = f.Messages.Where(m => m.Topic == null).Count(),
                      NumberOfMessage = f.Messages.Count(),
                      LastMessageDate = msg.CreationDate,
                      LastMessageTitle = msg.Title
                  };
     
    return results;
    Les règles du forum
    Le trio magique : FAQ + Cours + fonction rechercher
    Mes articles
    Pas de questions par messages privés svp

    Software is never finished, only abandoned.

  3. #3
    Membre émérite Avatar de neptune
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2003
    Messages : 835
    Par défaut
    Et oui, quand tu veux explorer une nouvelle technologie il faut bien s'atteler un projet, même s'il ne mènera peut etre nulle part ;-)

    Mince, je connaissais pas let! Mais, apparement, ce n'est qu'un raccourci pour éviter de dupliquer deux fois la même chose. Niveau SQL, ca génère toujours deux fois le même subselect.

    Merci quand même pour ton conseil, j'ai appris un nouveau mot clé. Je vais tout de même voir la doc, peut-être que c'est tout de même une bonne piste.

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/05/2015, 21h49
  2. LINQ, type anonyme et databinding
    Par lutecefalco dans le forum ASP.NET
    Réponses: 2
    Dernier message: 23/02/2009, 19h42
  3. linq et reporting services - types anonymes
    Par boby62423 dans le forum Linq
    Réponses: 0
    Dernier message: 03/02/2009, 12h06
  4. [C# 3]Passer un type anonyme à une fonction
    Par NicolasJolet dans le forum C#
    Réponses: 2
    Dernier message: 10/09/2008, 16h17
  5. [collection] Type anonyme + IEnumerable
    Par ZaaN dans le forum C#
    Réponses: 6
    Dernier message: 08/04/2008, 15h03

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