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

C# Discussion :

Incrementer un int. Please kill me


Sujet :

C#

  1. #1
    Invité
    Invité(e)
    Par défaut Incrementer un int. Please kill me
    Bonjour,

    Si personne n'a de réponse a cette question, je vais en perdre le someil !

    Voici une requete Linq tout a fait fonctionelle. La seul valeur interessante ici est "Instance".
    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
     
     var list = (from s in Context.GP_VisiteNames
              where s.VN_IsSpetial == false
              where s.VN_OutOfDate == null
              select new VisitCreatorViewModel()
              {
                 DateStart = new CalendarViewModel() { Date = DateTime.Now, Instance = 0 }, // <=== ICI
                 RameId = 0,
                 RameName = new AutocompleteStringViewModel() { Value = null },
                 VisitName = s.VN_Name,
                 Visit = new DropDownListViewModel()
                 {
                    DropDownOptions = (from t in Context.GP_VisiteNames
                                       where t.VN_OutOfDate == null
                                       select new DropDownOption()
                                       {
                                          Value = t.VN_ID,
                                          Label = t.VN_Name
                                       }).ToList()
                 }
              }).ToList();
    Je souhaites incrementer le champ instance. Ne pouvant pas/n'ayant pas trouvé le moyen de la faire dans la requete, Je le fais en dehors.

    Une fois la requete effectuée, j'ai une liste contenant 15 VisitCreatorViewModel, chaqun contient un CalendarViewModel ayant un champ public int Instance.

    Voici comment j'ai voulu incrémenter les Instances et vous constaterez que peu a peu la follie s'empare de moi. Car a la fin de chaque boucle, TOUTES oui TOUTES les valeurs d'Instance valent 14.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    //1
    for (int i = 0; i < list.Count; ++i)
       list[i].DateStart.Instance = i;
    //2
    int i = 0;
    foreach (var item in list)
       item.DateStart.Instance = ++i;
    //3
    for (int i = 0; i < list.Count; ++i)
       if (i > 0)
          list[i].DateStart.Instance = list[i - 1].DateStart.Instance + 1;
    Ca me rends fou. On ne peut pas faire une simple incrementation en C# ?
    Pourquoi est-ce tout le temps une référence qui est passé par l'opérateur "=" ?

    Merci pour toute aide !

  2. #2
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 743
    Points
    9 743
    Billets dans le blog
    3
    Par défaut
    A priori la méthode n°2 fonctionne correctement.

    Sinon tu dois aussi pouvoir faire un truc du genre :
    Code C# : 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
    var t = 0;
    var list = (from s in Context.GP_VisiteNames
              where s.VN_IsSpetial == false
              where s.VN_OutOfDate == null
              select new VisitCreatorViewModel()
              {
                 DateStart = new CalendarViewModel() { Date = DateTime.Now, Instance = ++t }, // <=== ICI
                 RameId = 0,
                 RameName = new AutocompleteStringViewModel() { Value = null },
                 VisitName = s.VN_Name,
                 Visit = new DropDownListViewModel()
                 {
                    DropDownOptions = (from t in Context.GP_VisiteNames
                                       where t.VN_OutOfDate == null
                                       select new DropDownOption()
                                       {
                                          Value = t.VN_ID,
                                          Label = t.VN_Name
                                       }).ToList()
                 }
              }).ToList();
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Lorsque je fais un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DateStart = new CalendarViewModel() { Date = DateTime.Now, Instance = ++t },
    J'ai l'erreur "An expression tree may not contain an assignement operator"

    Et non la methode 2 no fonctione vraiment pas

    j'ai mi une condition pour tester
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if (list[0].DateStart.Instance != 0)
       i = 0; // Breackpoint placcé ici. Le i = 0 ne sert a rien a part verifier si je rentres dans le if.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Je ne suis pas certain de bien comprendre pourquoi, mais voila comment j'ai réussi a résourdre le problème :
    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
    var t = 0;
    var list = (from s in Context.GP_VisiteNames
              where s.VN_IsSpetial == false
              where s.VN_OutOfDate == null
              select s)
              .AsEnumerable()
              .select(d => new VisitCreatorViewModel()
              {
                 DateStart = new CalendarViewModel() { Date = DateTime.Now, Instance = ++t }, // <=== ICI
                 RameId = 0,
                 RameName = new AutocompleteStringViewModel() { Value = null },
                 VisitName = d.VN_Name,
                 Visit = new DropDownListViewModel()
                 {
                    DropDownOptions = (from t in Context.GP_VisiteNames
                                       where t.VN_OutOfDate == null
                                       select new DropDownOption()
                                       {
                                          Value = t.VN_ID,
                                          Label = t.VN_Name
                                       }).ToList()
                 }
              }).ToList();

  5. #5
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 743
    Points
    9 743
    Billets dans le blog
    3
    Par défaut
    Ben c'est bizarre. J'ai reproduit gross modo ton cas sur mon ordi (avec une List<> à la place de ton Context.GP_VisiteNames).

    Lorsque je place le code de ta méthode n°2 après la requête LinQ, j'ai bien une incrémentation de la variable Instance.

    [EDIT] : Ton if n'est pas un cas valide, car tu n'as forcément aucune variable Instance égale à 0, puisque tu incrémentes directement. On commence donc à 1.
    J'ai lu trop vite. C'est valide.

    Avec le cas que tu as posté entre temps, ça fonctionne ?
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  6. #6
    Membre éclairé Avatar de chamamo
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    588
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 588
    Points : 735
    Points
    735
    Par défaut
    Citation Envoyé par DotNetMatt Voir le message
    Ben c'est bizarre. J'ai reproduit gross modo ton cas sur mon ordi (avec une List<> à la place de ton Context.GP_VisiteNames).
    Normal car tu as essayé avec Linq To Object,

    Sa requête n'a pas pu être traduite en Sql

    il faut faire comme tu as fait, AsEnumerabe() ensuite affecter ta propriété.

  7. #7
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 743
    Points
    9 743
    Billets dans le blog
    3
    Par défaut
    Oui, mais l'incrémentation étant faite à postériori (sa méthode n°2), la requête avait déjà été générée. C'est étrange d'obtenir ce comportement.
    Less Is More
    Pensez à utiliser les boutons , et les balises code
    Desole pour l'absence d'accents, clavier US oblige
    Celui qui pense qu'un professionnel coute cher n'a aucune idee de ce que peut lui couter un incompetent.

  8. #8
    Membre éclairé Avatar de chamamo
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    588
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 588
    Points : 735
    Points
    735
    Par défaut
    Citation Envoyé par DotNetMatt Voir le message
    Oui, mais l'incrémentation étant faite à postériori (sa méthode n°2), la requête avait déjà été générée. C'est étrange d'obtenir ce comportement.
    Effectivement j'avais pas vu, ça devrait marcher.

    Tu peux donner la classe CalendarViewModel?

  9. #9
    Invité
    Invité(e)
    Par défaut
    C'est une classe toute simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public class CalendarViewModel
    {
       public int Instance { get; set; }
       public DateTime Date { get; set; }
    }
    Edit: Le dernier exemple que j'ai fourni est fonctionnel et l'incrementation commence a 1.

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

Discussions similaires

  1. [.COM] Réserver de la RAM fct 48h int 21h
    Par bulerias dans le forum x86 16-bits
    Réponses: 5
    Dernier message: 06/12/2010, 14h33
  2. [Dev c++ 4] implicite declaration of function "int kbhi
    Par Torpedox dans le forum Dev-C++
    Réponses: 5
    Dernier message: 01/01/2003, 13h37
  3. "ALTERER" une col. NULL en NOT NULL - Int
    Par Gandalf24 dans le forum SQL
    Réponses: 2
    Dernier message: 28/12/2002, 00h07
  4. Pb d'auto-incrément sur une table v7
    Par Nivux dans le forum Paradox
    Réponses: 9
    Dernier message: 26/12/2002, 12h05
  5. Les INT en mode protégé
    Par le mage tophinus dans le forum x86 16-bits
    Réponses: 8
    Dernier message: 05/12/2002, 16h13

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