Подтвердить что ты не робот

Анонимный тип и несколько свойств

У меня есть эта ошибка: анонимный тип не может иметь несколько свойств с тем же именем. Может ли это быть разрешено с помощью псевдонима, т.е. Существует ли псевдоним в LINQ

var device_query = from d in DevicesEntities.device
             join dt in DevicesEntities.devicetype on d.DeviceTypeId equals dt.Id
             join l in DevicesEntities.location on d.Id equals l.DeviceId
             join loc in DevicesEntities.locationname on l.LocationNameId equals loc.Id
                           where l.DeviceId == d.Id
                           select new {
                               d.Id,
                               d.DeviceTypeId,
                               d.SerialNumber,
                               d.FirmwareRev,
                               d.ProductionDate,
                               d.ReparationDate,
                               d.DateOfLastCalibration,
                               d.DateOfLastCalibrationCheck,
                               d.CalCertificateFile,
                               d.Notes,
                               d.TestReportFile,
                               d.WarrantyFile,
                               d.CertificateOfOriginFile,
                               d.QCPermissionFile,
                               d.Reserved,
                               d.ReservedFor,
                               d.Weight,
                               d.Price,
                               d.SoftwareVersion,
                               dt.Name,
                               dt.ArticleNumber,
                               dt.Type,
                               l.StartDate, //AS LastStartDate,
                               l.LocationNameId,
                               loc.Name //in this line I have problem
                           };
4b9b3361

Ответ 1

Вам нужно предоставить альтернативные имена для повторяющихся свойств. Например:

select new {
   // ... other properties here ...
   dt.Name,
   dt.ArticleNumber,
   dt.Type,
   LastStartDate = l.StartDate,
   l.LocationNameId,
   CurrentLocation = loc.Name
};

Ответ 2

Это confligt на "Name" Вы сопоставляете как dt.Name, так и loc.Name, оба из которых компилятор пытается установить свойство "Name" для типа anon.

изменить один из них, например, LoationName = loc.Name.

НТН

[править] Слишком поздно попасть в submit: -)