What would be an EF method syntax equivalent for the following TSQL query?
select istb.service_id, ss.service_desc, selected=1
from istb_services istb
inner join setup_services ss on istb.service_id=ss.service_id
where istb.istb_id=3
union
select ss.service_id, ss.service_desc, selected=0
from setup_services ss
where ss.service_id not in (select service_id from istb_services where istb_id=3)
I tried converting the not in part of the query like following:
var _existing = context.istb_services.Where(e => e.istb_id == IstbID);
var _others = context.setup_services.Except(_existing);
but it is generating compile-time error:
The best overloaded method match for ‘System.Data.Objects.ObjectQuery.Except(System.Data.Objects.ObjectQuery)’ has some invalid arguments
I understand I can’t pass different type of ObjectQuery to the .Except method but then what would be the alternative code?
Thanks,
Try the following:
Anonymous type initializers having identical fields should be compiled to the same anonymous type, making the two sequences compatible for the
Unionoperation.