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

Accès aux données Discussion :

LinqToEntities, le sql généré dépend il du provider?


Sujet :

Accès aux données

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    284
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 284
    Points : 79
    Points
    79
    Par défaut LinqToEntities, le sql généré dépend il du provider?
    Bonjour,

    Je me pose actuellement une petite question.
    J'ai réalisé une application WPF qui interroge une base de données MySQL via EntityFramework (LinqToEntity).
    Mon provider est MySQL Connector 6.3.4.

    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    var query = Db.table1
    				.Include("table2")
    				.Include("table3")
    				.Include("table4");
     
    var resultat = query.ToList();

    Le code ci dessous est transformé en SQL et exécuté au moement où je fais le ToList();

    Petite question
    Qui est ce qui fait la transformation ?
    - le provider (donc MySQL Connector 6.3.4)?
    - un mécanisme au sein de l'EDMX?
    - autre?

    Par avance merci pour vos réponses.

  2. #2
    Rédacteur
    Avatar de Nathanael Marchand
    Homme Profil pro
    Expert .Net So@t
    Inscrit en
    Octobre 2008
    Messages
    3 615
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert .Net So@t
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2008
    Messages : 3 615
    Points : 8 080
    Points
    8 080
    Par défaut
    Chaque requête linq est un arbre d'Expression. C'est le provider SQL qui prend cet arbre et le transforme en requête SQL.

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Et donc oui, le SQL généré est spécifique au provider utilisé. Par exemple SQL Server et MySQL n'ont pas exactement les mêmes fonctionnalités, et le provider tire parti des spécificités du SGBD cible

Discussions similaires

  1. Comment recupérer le code SQL généré par Hibernate !
    Par nebisse dans le forum Hibernate
    Réponses: 14
    Dernier message: 21/08/2008, 23h56
  2. Réponses: 6
    Dernier message: 04/06/2008, 13h27
  3. importer fichier .SQL généré par mysql vers MSSqlServer 2005
    Par Themacleod1980 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 19/01/2007, 15h49
  4. Code SQL généré différent d'attendu
    Par MxPx_23 dans le forum Hibernate
    Réponses: 2
    Dernier message: 07/09/2006, 10h26
  5. [Hibernate3] Anomalies dans le SQL généré
    Par mauvais_karma dans le forum Hibernate
    Réponses: 6
    Dernier message: 16/08/2005, 09h58

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