Domanda

In SQL puoi eseguire un ISNULL (null, '') come lo faresti in una query linq?

Ho aderito a questa query:

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

ma ho una colonna con un tipo di bit non nullable (xx.online) come posso impostarlo su false se è null?

È stato utile?

Soluzione

Dato che aa è l'insieme / oggetto che potrebbe essere nullo, puoi controllare aa == null ?

( aa / xx potrebbe essere intercambiabile (un refuso nella domanda); la domanda originale parla di xx ma definisce solo AA )

cioè.

select new {
    AssetID = x.AssetID,
    Status = aa == null ? (bool?)null : aa.Online; // a Nullable<bool>
}

o se si desidera che l'impostazione predefinita sia false (non null ):

select new {
    AssetID = x.AssetID,
    Status = aa == null ? false : aa.Online;
}

Aggiornamento; in risposta al downvote, ho studiato di più ... il fatto è che questo è l'approccio giusto! Ecco un esempio su 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);
            }
        }

Ed ecco il TSQL - praticamente quello che vogliamo (non è ISNULL , ma è abbastanza vicino):

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?

Altri suggerimenti

Puoi usare l'operatore ?? per impostare il valore predefinito, ma prima devi impostare la proprietà Nullable su true nel tuo dbml nel campo richiesto ( 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
        };

Ho spesso questo problema con le sequenze (al contrario dei valori discreti). Se ho una sequenza di ints e voglio sommarli, quando l'elenco è vuoto riceverò l'errore " InvalidOperationException: il valore null non può essere assegnato a un membro con tipo System.Int32 che è un nullable tipo di valore. " ;.

Trovo di poterlo risolvere lanciando la sequenza su un tipo nullable. SUM e gli altri operatori aggregati non generano questo errore se una sequenza di tipi nullable è vuota.

Quindi ad esempio qualcosa del genere

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

diventa

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

Il secondo restituirà 0 quando nessuna riga corrisponde alla clausola where. (il primo genera un'eccezione quando nessuna riga corrisponde).

Sembra che il tipo sia booleano e quindi non può mai essere nullo e dovrebbe essere falso per impostazione predefinita.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top