Loading...
aivian avatar aivian 51 Точки

[Homework] DB Apps - Problem 3

Може ли някой по - опитен да ми преведе тази SQL заявка в LINQ синтаксис:

pastebin.com/GxgwuURF

Имам затруднения с четирите подточки от трета задача. Издокарах тази заявка:

http://pastebin.com/Kwxxe0an

но не знам как да взема и името на мениджъра.

Тагове:
-1
Databases Basics 20/07/2015 14:21:32
Filkolev avatar Filkolev 4482 Точки

Проблемът е в първия селект, където вадиш само проектите и вече нямаше достъп до нужната ти информация от служителите.

Първо, трябва да имаш Where, в който да посочиш кои служители искаш да филтрираш - в условието на Where търсиш в проектите на служителя дали има такъв, който е стартирал в дадения диапазон. След това в селект-а може да извадиш всичко необходимо за служителите, а отделно от техните проекти може да вземеш каквото се изисква с още един селект. Ето какво имам предвид:

 var employeesWithProjects = context.Employees
                    .Where(e => e.Projects
                        .Any(p => p.StartDate.Year >= 2001 && p.StartDate.Year <= 2003))
                    .Select(e => new
                    {
                        e.FirstName,
                        e.LastName,
                        ManagerName = e.Manager.FirstName + " " + e.Manager.LastName,
                        Projects = e.Projects.Select(p => new
                        {
                            p.Name,
                            p.StartDate,
                            p.EndDate
                        })
                    }); 

1
20/07/2015 14:35:17
aivian avatar aivian 51 Точки

Дава ми грешка, че няма поле Manager, а само ManagerID. Как да открия Manager - а?

0
Filkolev avatar Filkolev 4482 Точки

Не си си коригирал имената на пропъртитата в такъв случай. Вероятно EF ти го е кръстил Employee, Employee1 или нещо такова. Виж си диаграмата и виж къде би трябвало да се пази мениджъра и на него му вземи името (в случая аз взимам първо име и фамилия, понеже е казано само име в условието).

1
aivian avatar aivian 51 Точки

Да, така ги беше кръстил. Аз се замислих в началото какви са тези Employee1, но не ми мина през ума, че са мениджърите. Мерси за помощта.

0
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.