Kami memiliki entitas seperti ini:
public class File{
public int Region{get;set;}
public bool ShowLocation{get;set;}
//Other fields are omitted
}
Saya ingin menulis pertanyaan ini:
SELECT Region,SUM(CASE WHEN ShowLocation=1 THEN 1 ELSE 0 END) AS
ShowCount,SUM(CASE WHEN ShowLocation=0 THEN 1 ELSE 0 END) AS NotShowCount
--WHERE omitted for the sake of simplicity
GROUP BY Region
Untuk beberapa alasan saya ingin menggunakan Linq To Nhibernate (Kami memiliki mekanisme pemfilteran kompleks yang menghasilkan Expression<Func<File,bool>>
)
Sejauh ini saya tidak dapat menemukan cara untuk mencapai hal ini menggunakan Linq To NHibernate. Inilah beberapa upaya saya:
Jumlah Kondisi: (Tidak terkecuali tetapi tetap menghitung semua baris)
Files
.Where(whereExpression)
.GroupBy(x=>x.Region)
.Select(x=>new
{
x.Region,
ShowCount=x.Count(f=>f.ShowLocation==1),
NotShowCount=x.Count(f=>f.ShowLocation==0)
});
Jumlah Kondisi : Tidak Didukung/Pengecualian yang Diimplementasikan
Files
.Where(whereExpression)
.GroupBy(x=>x.Region)
.Select(x=>new
{
x.Region,
ShowCount=x.SUM(f=>f.ShowLocation==1?1:0),
NotShowCount=x.SUM(f=>f.ShowLocation==0?1:0)
});
SELECT Sebelum GROUP : Tidak Didukung/Pengecualian yang Diimplementasikan
Files.Where(whereExpression).Select(x=>new
{
x.Region,
Show=x.ShowLocation==1?1:0,
NotShow=x.ShowLocation==0?1:0
})
.GroupBy(x=>x.Region)
.Select(x=>new
{
x.Region,
ShowCount=x.SUM(f=>f.Show),
NotShowCount=x.SUM(f=>f.NotShow)
});
UNION : Tidak Didukung/Diimplementasikan Pengecualian
Files
.Where(whereExpression)
.Where(x=>x.ShowLocation==1)
.Select(x=>new
{
x.Region,
Show=1,NotShow=0
})
.Union(Files
.Where(whereExpression)
.Where(x=>x.ShowLocation==0)
.Select(x=>new
{x.Region,
Show=0,
NotShow=1
}))
.GroupBy(x=>x.Region)
.Select(x=>new
{
x.Region,
CountShow=x.Count(a=>a.Show),
CountNotShow=x.Count(a=>a.NotShow)
});
Saya tidak punya petunjuk lain. Ada ide lain?