Эквивалент SQL ISNULL в LINQ? - PullRequest
       24

Эквивалент SQL ISNULL в LINQ?

49 голосов
/ 05 января 2009

В 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), как я могу установить для него значение false, если оно равно NULL?

Ответы [ 4 ]

58 голосов
/ 05 января 2009

Поскольку aa - это набор / объект, который может быть нулевым, вы можете проверить aa == null?

(aa / xx может быть взаимозаменяемым (опечатка в вопросе); оригинальный вопрос говорит о xx, но определяет только aa)

1011 * т.е. *

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;
}

Update; в ответ на понижение голосов я исследовал больше ... факт, это - правильный подход! Вот пример на 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

24 голосов
/ 05 января 2009

Вы можете использовать оператор ?? для установки значения по умолчанию, но сначала вы должны установить для свойства Nullable значение true в файле dbml в необходимом поле (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
        };
1 голос
/ 28 августа 2010

У меня часто возникает эта проблема с последовательностями (в отличие от дискретных значений). Если у меня есть последовательность целых чисел, и я хочу суммировать их, когда список пуст, я получу сообщение об ошибке "InvalidOperationException: Нулевое значение не может быть назначено члену с типом System.Int32, который является ненулевым значением типа. ".

Я считаю, что могу решить эту проблему, приведя последовательность к обнуляемому типу. SUM и другие агрегирующие операторы не выдают эту ошибку, если последовательность пустых типов пуста.

Так, например, что-то вроде этого

MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => x.AnIntegerValue);

становится

MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => (int?) x.AnIntegerValue);

Второй вернет 0, если ни одна строка не соответствует предложению where. (первый выдает исключение, если ни одна строка не соответствует).

0 голосов
/ 05 января 2009

Похоже, что тип является логическим, и поэтому никогда не может быть нулевым и должен иметь значение по умолчанию.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...