Linq to SQL [Résolu]

Messages postés
18
Date d'inscription
lundi 8 novembre 2004
Statut
Membre
Dernière intervention
26 avril 2010
- - Dernière réponse : krimog
Messages postés
1863
Date d'inscription
lundi 28 novembre 2005
Statut
Modérateur
Dernière intervention
14 février 2015
- 24 juin 2009 à 16:59
Baptiste
Bonjour à tous,
Je développe actuellement pour ma société une appli c#(sous Microsoft Visual C# 2008 Express) avec une DB distante sous Microsoft SQL Server 2005 standard.
Pour le traitement des données je souhaite utiliser la technologie Linq qui, en vu des différents posts, a l'air puissante.
Pour tester "Linq" j'ai suivi le tuto de odahan http://www.csharpfr.com/tutoriaux/PRESENTATION-LINQ-AVEC-CSHARP_784.aspx

Au niveau de SQL Server j'ai une DB "ma_base" qui contient une table "ma_table".
j'ai donc créé une class pour mapper cette table:

using System.Data.Linq;
using System.Data.Linq.Mapping;

namespace mon_namespace
{
public class TableContext : DataContext
{

public Table<ma_table_mapping> Table;

public ServiceContext(string fileOrServerOrConnection)
: base(fileOrServerOrConnection)
{}
}

[Table(Name="ma_table")]
public class ma_table_mapping
{
private int my_Id;
[Column(IsPrimaryKey = true, Name = "id", Storage = "my_Id")]
public int Id
{
get{return this.my_Id;}
set{this.my_Id = value;}
}

private string my_Libelle;
[Column(Name="libelle",Storage = "my_Libelle")]
public string Libelle
{
get{return this.my_Libelle;}
set{this.my_Libelle = value;}
}
}
}

Ensuite sur un formulaire j'ai fais le test suivant:

private void TestLinq()
{
TableContext aTableContext = new TableContext (Program.STR_DB_CONNEXION);
aTableContext.Log = Console.Out; // affiche le SQL sur la console
var query = aTableContext.Table; // requête ultra simple: toute la table
ObjectDumper.Write(query); // affiche le résultat
Console.ReadLine();
}

Le résultat est correcte :
Id=1 Libelle=Libelle1
Id=2 Libelle=Libelle2
Id=3 Libelle=Libelle3
SELECT [t0].[id] AS [Id], [t0].[libelle] AS [Libelle]
FROM [ma_table] AS [t0].

Par contre si, par exemple, je ne veux que le libelle ca ne passe plus a la compil:
private void TestLinq()
{
TableContext aTableContext = new TableContext (Program.STR_DB_CONNEXION);
aTableContext.Log = Console.Out; // affiche le SQL sur la console
var query = From lib in aTableContext.Table select Libelle;
ObjectDumper.Write(query); // affiche le résultat
Console.ReadLine();
}

Erreur de compil:
Impossible de trouver une implémentation du modèle de requête pour le type source 'System.Data.Linq.Table<mon_namespace.ma_table_mapping>'. 'Select' introuvable. Une référence à 'System.Core.dll' ou une directive using pour 'System.Linq' est-elle manquante ?

Je ne trouve pas de solution, merci d'avance pour votre aide.</mon_namespace.ma_table_mapping></ma_table_mapping>
Afficher la suite 

4 réponses

Meilleure réponse
Messages postés
1863
Date d'inscription
lundi 28 novembre 2005
Statut
Modérateur
Dernière intervention
14 février 2015
24
3
Merci
Dans ce cas, désolé de ma remarque. C'est juste que j'ai vu dans tes using System.Data.Linq mais pas System.Linq. Et ce petit détail m'avait déjà donné une erreur proche de la tienne si ce n'est identique.

Krimog : while (!(succeed = try())) ;
- NON, "LE BAR" n'est PAS un langage de programmation ! -

Dire « Merci » 3

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

Codes Sources 121 internautes nous ont dit merci ce mois-ci

Commenter la réponse de krimog
Messages postés
18
Date d'inscription
lundi 8 novembre 2004
Statut
Membre
Dernière intervention
26 avril 2010
0
Merci
Bonjour à tous,
Je développe actuellement pour ma société une appli c#(sous Microsoft Visual C# 2008 Express) avec une DB distante sous Microsoft SQL Server 2005 standard. Pour le traitement des données je souhaite utiliser la technologie Linq qui, en vu des différents posts, a l'air puissante. Pour tester "Linq" j'ai suivi le tuto de odahan http://www.csharpfr.com/tutoriaux/PRESENTATION-LINQ-AVEC-CSHARP_784.aspx
Au niveau de SQL Server j'ai une DB "ma_base" qui contient une table "ma_table".
J'ai donc créé une class pour mapper cette table:
using System.Data.Linq;
using System.Data.Linq.Mapping;
namespace mon_namespace
{
public class TableContext : DataContext
{
public Table<ma_table_mapping>;
public ServiceContext(string fileOrServerOrConnection) : base(fileOrServerOrConnection) {}
}

[Table(Name="ma_table")]
public class ma_table_mapping
{
private int my_Id;
[Column(IsPrimaryKey = true, Name = "id", Storage = "my_Id")]
public int Id { get{return this.my_Id;} set{this.my_Id = value;} }

private string my_Libelle;
[Column(Name="libelle",Storage = "my_Libelle")]
public string Libelle { get{return this.my_Libelle;} set{this.my_Libelle = value;}
}
}

Ensuite sur un formulaire j'ai fais le test suivant:
private void TestLinq()
{
TableContext aTableContext = new TableContext (Program.STR_DB_CONNEXION);
aTableContext.Log = Console.Out; // affiche le SQL sur la console
var query = aTableContext.Table; // requête ultra simple: toute la table
ObjectDumper.Write(query); // affiche le résultat Console.ReadLine();
}

Le résultat est correcte :
Id=1 Libelle=Libelle1
Id=2 Libelle=Libelle2
Id=3 Libelle=Libelle3
SELECT [t0].[id] AS [Id], [t0].[libelle] AS [Libelle] FROM [ma_table] AS [t0].

Par contre si, par exemple, je ne veux que le libelle ca ne passe plus a la compil:
private void TestLinq()
{
TableContext aTableContext = new TableContext (Program.STR_DB_CONNEXION);
aTableContext.Log = Console.Out; // affiche le SQL sur la console
var query = From lib in aTableContext.Table select Libelle;
ObjectDumper.Write(query); // affiche le résultat
Console.ReadLine();
}

Erreur de compil:
Impossible de trouver une implémentation du modèle de requête pour le type source 'System.Data.Linq.Table'. 'Select' introuvable. Une référence à 'System.Core.dll' ou une directive using pour 'System.Linq' est-elle manquante ?

Je ne trouve pas de solution, merci d'avance pour votre aide.
Commenter la réponse de bcazard
Messages postés
1863
Date d'inscription
lundi 28 novembre 2005
Statut
Modérateur
Dernière intervention
14 février 2015
24
0
Merci
Salut
L'erreur parle d'elle même.

Ajoute using System.Linq; à ton fichier, et, si elle n'y est pas déjà, ajoute une référence à System.Core.dll dans ton projet.

Krimog : while (!(succeed = try())) ;
- NON, "LE BAR" n'est PAS un langage de programmation ! -
Commenter la réponse de krimog
Messages postés
18
Date d'inscription
lundi 8 novembre 2004
Statut
Membre
Dernière intervention
26 avril 2010
0
Merci
Salut,
merci de ta réponse, mais j'ai bientot 10 ans de .NET donc si ce n'etait que ça je n'aurais pas demandé d'aide ;).
Il n'y a pas de probleme pour récupérer la table complete => le linq se fait correctement(en tout cas le résultat est cohérant avec ma DB).

C'est sur des requetes de type:
var query = from lib in aTableContext.Table ... que ça plante:
Impossible de trouver une implémentation du modèle de requête pour le type source 'System.Data.Linq.Table'.
Commenter la réponse de bcazard