У меня есть 3 таблицы:
Dealerships
------------
ID, Name, Website
Locations
------------
ID, DealershipID, Address, Ect.
Contacts
------------
ID, LocationID, Name, Ect.
Таким образом, отношения показывают, что у нас есть дилерские центры с несколькими местоположениями (например: Weed Chevrolet из PA, Weed Chevrolet из Нью-Джерси), а затем у каждого местоположения есть свои контакты(Пример: менеджеры локации PA, менеджеры локации NJ).Мне нужно объединить 3 таблицы вместе.Вот что у меня есть:
var results = from d in entities.dealerships
join l in entities.locations on d.ID equals l.DealershipID
join c in entities.contacts on l.ID equals c.LocationID
select new
{
Name = d.Name,
Website = d.Website,
Address = l.Address + ", " + l.City + ", " + l.State + " " + l.Zip,
Contact = c.FirstName + " " + c.LastName,
WorkPhone = c.WorkPhone,
CellPhone = c.CellPhone,
HomePhone = c.HomePhone,
Email = c.Email,
AltEmail = c.AltEmail,
Sells = l.Sells
}
Когда я пытаюсь связать результаты с BindingSource, а затем с DataGridView, я получаю следующую ошибку:
Unable to cast the type 'System.Nullable`1' to type 'System.Object'.
LINQ to Entities only supports casting Entity Data Model primitive types.
Что это может быть?Я новичок в операторах JOIN в LINQ, поэтому я уверен, что делаю что-то не так.
РЕДАКТИРОВАТЬ: в базе данных есть данные, поэтому результаты не должны быть нулевыми, просто чтобы уточнить