Конвертировать SQL в эквивалент LINQ - PullRequest
0 голосов
/ 14 февраля 2012

У меня проблемы с преобразованием этого синтаксиса в Linq:

SELECT 
    Medlemmer.Skif, 
    Grader.Grad, 
    Medlemmer.Navn, 
    Medlemmer.Mellemnavn, 
    Medlemmer.Efternavn, 
    Medlemmer.Adresse, 
    Medlemmer.Telefon, 
    Medlemmer.Mobil, 
    Medlemmer.PostNr, 
    Medlemmer.town, 
    Medlemmer.mail, 
    Medlemmer.Picture 
FROM 
    Medlemmer 
    CROSS APPLY Get_grader(Medlemmer.Skif) as Grader 
WHERE 
    Medlemmer.Aktiv = 1
ORDER BY 
    Medlemmer.Navn

Get_grader () - это функция, которая возвращает таблицу с данными)

Я здесь:

var q = from a in db.GetTable<Medlemmer>()
           where a.Aktiv == true
           orderby a.Navn
           select new
               {
                 Grad = db.Get_grader(Convert.ToInt32(a.Skif)),
                 Skif = a.Skif,
                 Navn = a.Navn,
                 Mellemnavn = a.Mellemnavn,
                 Efternavn = a.Efternavn,
                 Adresse = a.Adresse,
                 Telefon = a.Telefon,
                 Mobil = a.Mobil,
                 PostNr = a.PostNr,
                 town = a.town,
                 mail = a.mail,
                 Picture = a.Picture 
               };

Прямо сейчас Grad возвращает "System.Collections.Generic.List`1 [Get_grader]"

Как получить правильное значение?

Ответы [ 2 ]

2 голосов
/ 14 февраля 2012

Я не смог проверить, но попробуйте это:

var q = from a in db.GetTable<Medlemmer>()
        from g in db.Get_grader(Convert.ToInt32(a.Skif))
           where a.Aktiv == true
           orderby a.Navn
           select new
               {
                 Grad = g.Grad,
                 Skif = a.Skif,
                 Navn = a.Navn,
                 Mellemnavn = a.Mellemnavn,
                 Efternavn = a.Efternavn,
                 Adresse = a.Adresse,
                 Telefon = a.Telefon,
                 Mobil = a.Mobil,
                 PostNr = a.PostNr,
                 town = a.town,
                 mail = a.mail,
                 Picture = a.Picture 
               };
2 голосов
/ 14 февраля 2012

Может быть, что-то вроде этого:

var q = from a in db.GetTable<Medlemmer>()
            from grad in db.Get_grader(Convert.ToInt32(a.Skif))
           where a.Aktiv == true
           orderby a.Navn
           select new
               {
                 Skif = a.Skif,
                 Grad =grad.Grad
                 Navn = a.Navn,
                 Mellemnavn = a.Mellemnavn,
                 Efternavn = a.Efternavn,
                 Adresse = a.Adresse,
                 Telefon = a.Telefon,
                 Mobil = a.Mobil,
                 PostNr = a.PostNr,
                 town = a.town,
                 mail = a.mail,
                 Picture = a.Picture 
               };

Или если вы хотите список просто грейдер. Тогда что-то вроде этого может быть:

var q = from a in db.GetTable<Medlemmer>()
           where a.Aktiv == true
           orderby a.Navn
           select new
               {
                 Skif = a.Skif,
                 Grad = db.Get_grader(Convert.ToInt32(a.Skif))
                                       .Select(s=>s.Grad),
                 Navn = a.Navn,
                 Mellemnavn = a.Mellemnavn,
                 Efternavn = a.Efternavn,
                 Adresse = a.Adresse,
                 Telefon = a.Telefon,
                 Mobil = a.Mobil,
                 PostNr = a.PostNr,
                 town = a.town,
                 mail = a.mail,
                 Picture = a.Picture 
               };
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...