SQLでは、ISNULL(null、 '')を実行できますが、linqクエリでこれをどのように行いますか?
このクエリに結合があります:
var hht = from x in db.HandheldAssets
join a in db.HandheldDevInfos on x.AssetID equals a.DevName into DevInfo
from aa in DevInfo.DefaultIfEmpty()
select new
{
AssetID = x.AssetID,
Status = xx.Online
};
しかし、null可能でないビット型の列(xx.online)がありますが、nullの場合、これをfalseに設定するにはどうすればよいですか?
aa
はnullの可能性があるセット/オブジェクトなので、aa == null
?
(aa
/xx
は交換可能かもしれません(質問のタイプミス);元の質問はxx
について話しますが、aa
のみを定義します)
つまり.
select new {
AssetID = x.AssetID,
Status = aa == null ? (bool?)null : aa.Online; // a Nullable<bool>
}
または、デフォルトをfalse
(null
ではなく)にしたい場合:
select new {
AssetID = x.AssetID,
Status = aa == null ? false : aa.Online;
}
更新;投票に応じて、さらに調査しました...事実、これは正しいアプローチです! Northwindの例を次に示します。
using(var ctx = new DataClasses1DataContext())
{
ctx.Log = Console.Out;
var qry = from boss in ctx.Employees
join grunt in ctx.Employees
on boss.EmployeeID equals grunt.ReportsTo into tree
from tmp in tree.DefaultIfEmpty()
select new
{
ID = boss.EmployeeID,
Name = tmp == null ? "" : tmp.FirstName
};
foreach(var row in qry)
{
Console.WriteLine("{0}: {1}", row.ID, row.Name);
}
}
そして、ここにTSQLがあります-私たちが望むものはほとんど(ISNULL
ではありませんが、十分に近いです):
SELECT [t0].[EmployeeID] AS [ID],
(CASE
WHEN [t2].[test] IS NULL THEN CONVERT(NVarChar(10),@p0)
ELSE [t2].[FirstName]
END) AS [Name]
FROM [dbo].[Employees] AS [t0]
LEFT OUTER JOIN (
SELECT 1 AS [test], [t1].[FirstName], [t1].[ReportsTo]
FROM [dbo].[Employees] AS [t1]
) AS [t2] ON ([t0].[EmployeeID]) = [t2].[ReportsTo]
-- @p0: Input NVarChar (Size = 0; Prec = 0; Scale = 0) []
-- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 3.5.30729.1
QED?
??
演算子を使用してデフォルト値を設定できますが、最初にdbmlファイルでNullable
プロパティをtrue
に設定する必要があります必須フィールド(xx.Online
)
var hht = from x in db.HandheldAssets
join a in db.HandheldDevInfos on x.AssetID equals a.DevName into DevInfo
from aa in DevInfo.DefaultIfEmpty()
select new
{
AssetID = x.AssetID,
Status = xx.Online ?? false
};
私はしばしば(離散値ではなく)シーケンスでこの問題を抱えています。 intのシーケンスがあり、それらをSUMにしたい場合、リストが空のとき、エラー「InvalidOperationException:null値は、nullできない値であるSystem.Int32型のメンバーに割り当てることができません」を受け取ります。タイプ。"。
シーケンスをnull許容型にキャストすることでこれを解決できることがわかりました。 null許容型のシーケンスが空の場合、SUMおよびその他の集計演算子はこのエラーをスローしません。
たとえば、このようなもの
MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => x.AnIntegerValue);
になる
MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => (int?) x.AnIntegerValue);
2番目は、where句に一致する行がない場合、0を返します。 (最初の行は、一致する行がない場合に例外をスローします)。
型はブール型であるため、nullになることはないため、デフォルトではfalseになります。