Sdílet prostřednictvím


Jak: vyhledání minimální nebo maximální hodnotu ve výsledku dotazu pomocí LINQ (Visual Basic)

Integrované jazyk dotazu (LINQ) usnadňuje přístup k databázi informace a provádět dotazy.

Následující příklad ukazuje, jak vytvořit novou aplikaci, která provádí dotazy vůči databázi serveru SQL Server.Vzorek Určuje minimální a maximální hodnoty výsledků pomocí Aggregate a Group By klauzule.Další informace naleznete v tématu Agregační klauzule (Visual Basic) a Seskupit podle klauzule (Visual Basic).

Příklady v tomto tématu použít ukázkovou databázi Northwind.Pokud ukázkovou databázi Northwind ve vývojovém počítači nemáte, můžete ji stáhnout z Microsoft Download Center webu.Pokyny naleznete v části Downloading Sample Databases (LINQ to SQL).

[!POZNÁMKA]

Ve vašem počítači se pro některé z prvků uživatelského rozhraní sady Visual Studio mohou zobrazit jiné názvy a umístění, než jsou uvedeny v následujících pokynech. Tyto prvky jsou určeny verzí aplikace Visual Studio a použitým nastavením. Další informace naleznete v tématu Nastavení aplikace Visual Studio.

Vytvoření připojení k databázi

  1. Otevřít v aplikaci Visual Studio Server Explorer/Explorer databáze klepnutím na Server Explorer/Explorer databáze na zobrazení nabídce.

  2. Pravým tlačítkem myši na Připojení dat v Server Explorer/Explorer databáze a klepněte na tlačítko Přidat připojení.

  3. Zadejte platné připojení k ukázkové databázi Northwind.

Přidat projekt, který obsahuje LINQ soubor SQL

  1. V aplikaci Visual Studio na soubor nabídce přejděte na Nový a klepněte na tlačítko projektu.Výběr jazyka Visual Basic Model Windows Forms aplikace jako typ projektu.

  2. V nabídce Projekt klikněte na příkaz Přidat novou položku.Vyberte LINQ třídy SQL položku šablony.

  3. Název souboru northwind.dbml.Klikněte na tlačítko Přidat.Relační Object Designer (Návrhář O/R) je otevřen pro soubor northwind.dbml.

Přidání tabulky do dotazu na autora O/R

  1. V Server Explorer/Explorer databáze, rozbalte připojení k databázi Northwind.Rozbalte tabulek složky.

    Zavřeno O/R Designer můžete znovu otevřít poklepáním na soubor northwind.dbml, který jste přidali dříve.

  2. Klepněte na tabulku Zákazníci a přetáhněte ho do levého podokna Návrháře.Klepněte na tabulku objednávky a přetáhněte ho do levého podokna Návrháře.

    Návrhář vytváří nové Customer a Order objekty v projektu.Všimněte si, že návrhář automaticky rozpozná relace mezi tabulkami a vytvoří podřízené vlastnosti související objekty.Například technologie IntelliSense zobrazí Customer objekt má Orders týkající se vlastností pro všechny objednávky zákazníka.

  3. Uložte změny a zavřete Návrhář.

  4. Uložte projekt.

Přidání kódu k dotazu v databázi a zobrazit výsledky

  1. Z nástrojů, přetáhněte DataGridView řízení do výchozího formuláře systému Windows pro váš projekt Form1.

  2. Poklepejte na Form1 přidání kódu Load události formuláře.

  3. Po přidání tabulky do Návrháře O/R Návrhář přidány DataContext objektu pro projekt.Tento objekt obsahuje kód, který musí mít přístup k tyto tabulky vedle jednotlivých objektů a kolekcí pro každou tabulku.DataContext Objektu pro projekt s názvem na základě názvu souboru .dbml.Pro tento projekt DataContext s názvem objektu northwindDataContext.

    Můžete vytvořit instanci DataContext v kódu a dotazu tabulky určit návrhář O/R.

    Přidejte následující kód Load událostí.Tento kód dotazy, tabulky, které jsou vystaveny jako vlastnosti kontextu dat a určuje minimální a maximální hodnoty pro výsledky.Vzorek používá mu Aggregate klauzule dotazu pro jeden výsledek a Group By zobrazí průměr pro klauzule seskupeny výsledky.

    Dim db As New northwindDataContext
    
    Dim minimumOrders = Aggregate cust In db.Customers
                        Where cust.City = "London"
                        Into Min(cust.Orders.Count)
    
    MsgBox("Minimum Orders from a London Customer: " & minimumOrders)
    
    Dim maximumOrdersByCountry = From cust In db.Customers
                                 Group By cust.Country
                                   Into MaxOrders = Max(cust.Orders.Count)
    
    DataGridView1.DataSource = maximumOrdersByCountry
    
  4. Stisknutím klávesy F5 projektu spustit a zobrazit výsledky.

Viz také

Úkoly

Walkthrough: Creating LINQ to SQL Classes (O/R Designer)

Koncepty

DataContext Methods (O/R Designer)

Další zdroje

LINQ v jazyce Visual Basic

Dotazy (Visual Basic)

LINQ to SQL