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 :

LINQ to SQL : Nom de table variable.


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Dom-Tom

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2008
    Messages : 5
    Par défaut LINQ to SQL : Nom de table variable.
    Bonjour,

    J'ai plusieurs tables de structure identique.
    Seul leur nom change.
    Il est au format PYAAMMF avec AA l'année sur deux chiffres et MM le mois sur deux chiffres.
    Je dois récupérer les lignes de toutes ces tables pour les transférer vers une nouvelle table.
    J'utilise le code suivant pour récupérer les données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    var query = from f in ctx.PY9101F
                      select new
                      {
                              Nom = f.NOM,
                              Prenom = f.PRENOM
                       }
    var result = query.ToList();
    Étant donné qu'il y a plusieurs dizaines de tables, est-il possible de changer le nom de la table de manière dynamique dans la requête?

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    indirectement oui
    un dictionary <string, type de ta collection>
    le remplir
    et ensuite dans linq : from ... in dico(nom_collection_string)
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Dom-Tom

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2008
    Messages : 5
    Par défaut
    J'ai essayé avec le Dictionary mais je n'y arrive pas.
    Le query ne reconnait pas la collection comme un nom de table.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Dictionary<String, Object> t = new Dictionary<String, Object>();
    t.Add("9101", ctx.PY9101F);
     
    var query = from f in t("9101")
                      select new
                      {
                              NOM = f.NOM,
                              PRENOM = f.PRENOM
                      };
    Peut être que le type Object ne correspond pas mais je ne sais pas quel type conviendrait.

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 312
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
                    var query = from f in getObj()
                                select new
                                {
     
                                };
     
                }
            }
            private IEnumerable<object> getObj()
            {
                return null;
            }
    Tu met ça dans une méthode et ça devrait passer.

    Edit:
    Ah tu es en linq to Sql, mon exemple est en Linq to Object.
    Je ne peux pas tester +

  5. #5
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    tu as dit que tes collections avaient toute la même structure, j'en ai déduis le meme type, et il faut mettre ce type sur la déclaration du dictionary à la place d'object
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 312
    Par défaut
    Sinon, voir ici pour quelq'un qui a un problème très similaire :

    http://www.developpez.net/forums/d11...e/#post6110134

Discussions similaires

  1. SSIS - Requete sql avec nom de table variable
    Par IcedLand dans le forum Développement
    Réponses: 3
    Dernier message: 03/12/2007, 11h55
  2. SSIS - Requete sql avec nom de table variable
    Par IcedLand dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 03/12/2007, 11h55
  3. select dans SQL dynamique avec table variable
    Par enzodb2 dans le forum DB2
    Réponses: 4
    Dernier message: 26/07/2007, 16h28
  4. [PL/SQL] Nom de table et de champs paramétrés
    Par NeraOne dans le forum SQL
    Réponses: 16
    Dernier message: 18/07/2007, 16h47
  5. Nom de table variable ?
    Par szdavid dans le forum Oracle
    Réponses: 2
    Dernier message: 10/08/2005, 10h56

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