I am having trouble translating this his sql query into a linq expression that returns the results as an IEnumerable of a class.
This is the query:
Select * from Posts left outer join Ownergroups on
Posts.PostId=Ownergroups.PostID
Where Ownergroups.OwnerName = 'Group A' AND PostType = 'news'
This is the only expression that doesn't throw errors, but it also only returns a single result.
NewsViewModel vm = new NewsViewModel();
vm.NewsItems = (from an in db.Posts.Where(g => g.PostType == "News")
from og in an.OwnerGroups.Where(g => g.OwnerName == "Group A")
select an).Distinct().OrderByDescending(bb
=>bb.PostDate).ToList();
If I try to project to a new selection, I get an error. When I try to group by the PostId I get the proper results, but cannot attach the result to my ViewModel; I get an error saying "cannot convert type systems.collections.generic list to systems.collections.IEnumerable"
I'd really appreciate suggestions.
Adding the class, as requested:
public class Post
{
public int PostId { get; set; }
public string PostType { get; set; }
[Display(Name = "Top Title")]
[MaxLength(300)]
public string Headline1 { get; set; }
[Display(Name = "Subtitle")]
[MaxLength(300)]
public string Headline2 { get; set; }
public string Headline3 { get; set; }
[Display(Name = "By Organization or Person")]
[MaxLength(250)]
public string Byline { get; set; }
[Display(Name = "Text For Your Post")]
[MaxLength(4999)]
[AllowHtml]
public string PostText1 { get; set; }
[Display(Name = "Additional Text")]
[MaxLength(4999)]
[AllowHtml]
public string PostText2 { get; set; }
public string AuthorGroup { get; set; }
[Display(Name = "Link to Video (URL)")]
[MaxLength(249)]
public string AVurl { get; set; }
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:d}")]
public DateTime PostDate { get; set; }
[Display(Name = "Date To Archive")]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:d}")]
public DateTime? StopDate { get; set; }
[Display(Name = "Posted By")]
public string PostedBy { get; set; }
[Display(Name = "Last Edited")]
public DateTime LastEditDate { get; set; }
[Display(Name = "Last Edited By")]
public string LastEditor { get; set; }
public virtual ICollection<PostAsset> PostAssets { get; set; }
public virtual ICollection<PostAlbum> PostAlbums { get; set; }
public virtual ICollection<OwnerGroup> OwnerGroups { get; set; }