Condividi tramite


Formulare proiezioni

Negli esempi seguenti viene illustrato come è possibile combinare l'istruzione select in C# e l'istruzione Select in Visual Basic con altre funzionalità per formare proiezioni della query.

Esempio 1

Nell'esempio seguente viene usata la clausola Select in Visual Basic, ovvero la clausola select in C#, per restituire una sequenza di nomi di contatti per Customers.

var nameQuery =
    from cust in db.Customers
    select cust.ContactName;
Dim nameQuery = From cust In db.Customers _
                Select cust.ContactName

Esempio 2

Nell'esempio seguente viene usata la clausola Select in Visual Basic, ovvero la clausola select in C#, e tipi anonimi per restituire una sequenza di nomi e numeri di telefono per Customers.

var infoQuery =
    from cust in db.Customers
    select new { cust.ContactName, cust.Phone };
Dim infoQuery = From cust In db.Customers _
                Select cust.ContactName, cust.Phone

Esempio 3

Nell'esempio seguente viene usata la clausola Select in Visual Basic, ovvero la clausola select in C#, e tipi anonimi per restituire una sequenza di nomi e numeri di telefono per i dipendenti. I campi FirstName e LastName vengono combinati in un unico campo (Name) e il campo HomePhone viene rinominato in Phonenella sequenza risultante.

var info2Query =
    from emp in db.Employees
    select new
    {
        Name = emp.FirstName + " " + emp.LastName,
        Phone = emp.HomePhone
    };
Dim info2Query = From emp In db.Employees _
                 Select Name = emp.FirstName & " " & emp.LastName, _
             Phone = emp.HomePhone

Esempio 4

Nell'esempio seguente viene usata la clausola Select in Visual Basic, ovvero la clausola select in C#, e tipi anonimi per restituire una sequenza di tutte le voci presenti in ProductID e un valore calcolato denominato HalfPrice. Questo valore viene impostato su UnitPrice e diviso per 2.

var specialQuery =
    from prod in db.Products
    select new { prod.ProductID, HalfPrice = prod.UnitPrice / 2 };
Dim specialQuery = From prod In db.Products _
                   Select prod.ProductID, HalfPrice = CDec(prod.UnitPrice) / 2

Esempio 5

Nell'esempio seguente viene usata la clausola Select in Visual Basic, ovvero la clausola select in C#, e un'istruzione condizionale per restituire una sequenza di nome di prodotto e disponibilità del prodotto.

var prodQuery =
    from prod in db.Products
    select new
    {
        prod.ProductName,
        Availability =
            prod.UnitsInStock - prod.UnitsOnOrder < 0
        ? "Out Of Stock" : "In Stock"
    };
Dim prodQuery = From prod In db.Products _
                Select prod.ProductName, Availability = _
                    If(prod.UnitsInStock - prod.UnitsOnOrder < 0, _
                    "Out Of Stock", "In Stock")

Esempio 6

Nell'esempio seguente viene usata una clausola Select, ovvero una clausola select in C#, e un tipo conosciuto (Name) per restituire una sequenza di nomi di dipendenti.

public class Name
{
    public string FirstName = "";
    public string LastName = "";
}

 void empMethod()
 {
 Northwnd db = new Northwnd(@"c:\northwnd.mdf");
 var empQuery =
     from emp in db.Employees
     select new Name
     {
         FirstName = emp.FirstName,
         LastName = emp.LastName
     };
}
Public Class Name
    Public FirstName As String
    Public LastName As String
End Class

Dim db As New Northwnd("c:\northwnd.mdf")
Dim empQuery = From emp In db.Employees _
               Select New Name With {.FirstName = emp.FirstName, .LastName = _
                   emp.LastName}

Esempio 7

Nell'esempio seguente vengono usati Select e Where in Visual Basic, ovvero select e where in C#, per restituire una sequenza filtrata di nomi di contatti per i clienti nell'area londinese.

var contactQuery =
    from cust in db.Customers
    where cust.City == "London"
    select cust.ContactName;
Dim contactQuery = _
    From cust In db.Customers _
    Where cust.City = "London" _
    Select cust.ContactName

Esempio 8

Nell'esempio seguente viene usata una clausola Select in Visual Basic, ovvero una clausola select in C#, e tipi anonimi per restituire un subset con shaping dei dati sui clienti.

var custQuery =
    from cust in db.Customers
    select new
    {
        cust.CustomerID,
        CompanyInfo = new { cust.CompanyName, cust.City, cust.Country },
        ContactInfo = new { cust.ContactName, cust.ContactTitle }
    };
Dim custQuery = From cust In db.Customers _
                Select cust.CustomerID, CompanyInfo = New With {cust.CompanyName, _
                    cust.City, cust.Country}, ContactInfo = _
                    New With {cust.ContactName, cust.ContactTitle}

Esempio 9

Nell'esempio seguente vengono usate query annidate per restituire i risultati riportati di seguito:

  • Una sequenza di tutti gli ordini e dei corrispondenti OrderID.

  • Una sottosequenza degli elementi nell'ordine per cui è presente uno sconto.

  • L'importo risparmiato se il costo di spedizione non è incluso.

var ordQuery =
    from ord in db.Orders
    select new
    {
        ord.OrderID,
        DiscountedProducts =
            from od in ord.OrderDetails
            where od.Discount > 0.0
            select od,
        FreeShippingDiscount = ord.Freight
    };
Dim ordQuery = From ord In db.Orders _
               Select ord.OrderID, DiscountedProducts = _
               (From od In ord.OrderDetails _
                Where od.Discount > 0.0 _
                Select od), _
           FreeShippingDiscount = ord.Freight

Vedi anche