This is a basic question. I have the basic SL4/RIA project set up and I want to create a new method in the domain service and return some data from it. I am unsure the proper easiest way to do this.. Should I wrap it up in a ToList()? I am unclear how to handle this anonymous type that was create.. what is the easiest way to return this data?
public IQueryable<ApplicationLog> GetApplicationLogsGrouped()
{
var x = from c in ObjectContext.ApplicationLogs
let dt = c.LogDate
group c by new { y = dt.Value.Year, m = dt.Value.Month, d = dt.Value.Day } into mygroup
select new { aaa = mygroup.Key, ProductCount = mygroup.Count() };
return x;
// return this.ObjectContext.ApplicationLogs.Where(r => r.ApplicationID < 50);
}
Cannot implicitly convert type 'System.Linq.IQueryable<AnonymousType#1>' to 'System.Linq.IQueryable<CapRep4.Web.ApplicationLog>'. An explicit conversion exists (are you missing a cast?) 58 20 CapRep4.Web
An anonymous type is like any other class, but it's created by the compiler. What the compiler generates is something like:
class AnonymousType1 {
public AnonymousType2 Key { get; set; }
public int ProductCount { get; set; }
}
class AnonymousType2 {
public int y { get; set; }
public int m { get; set; }
public int d { get; set; }
}
Those classes are not accessible to you so you have no choice but to use a custom class matching the definition of Anonymous1 instead if you want to keep strong typing. You'll then use it like this: new MyClass { Key = myGroup.Key, ProductCount = mygroup.Count() }
.
Try using a KeyValuePair
public IQueryable<KeyValuePair<ApplicationLog,int>> GetApplicationLogsGrouped()
{
var x = from c in ObjectContext.ApplicationLogs
let dt = c.LogDate
group by c into mygroup
select new KeyValuePair<ApplicationLog,int>( mygroup.Key,mygroup.Count()) ;
return x;
// return this.ObjectContext.ApplicationLogs.Where(r => r.ApplicationID < 50);
}
You'll need to create your own class for the projection.
public class ApplicationLogStatistic
{
public ApplicationLog ApplicationLog { get; internal set; }
public int ProductCount { get; internal set; }
}
...
public IQueryable<ApplicationLogStatistic> GetApplicationLogsGrouped()
{
var x = // OP's code, except for select
select new ApplicationLogStatistic
{
ApplicationLog = mygroup.Key,
ProductCount = mygroup.Count()
};
return x;
}