Sdílet prostřednictvím


Práce s datově vázanými objekty v kódu

Aplikace LightSwitch generuje objekty a členy, které popisují data.Názvy těchto objektů a členů odpovídají názvům položek v řešení.Například při přidání tabulky s názvem Customer, LightSwitch vytvoří objekt nazvaný Customer.Toto téma popisuje všechny typy objektů, které lze vygenerovat pomocí aplikace LightSwitch.Chcete-li zobrazit příklady kódu, které tyto objekty a členy využít při provádění běžných úkonů souvisejících s daty, naleznete v části Provádění úloh souvisejících s daty pomocí kódu.

Hierarchie vygenerovaných objektů a členů

Následující obrázek obsahuje souhrn vygenerovaných objektů a členů datového modelu.

Hierarchie generovaného objektů

Aplikace

Objekt Application poskytuje nejvyšší úroveň přístupu k objektům v aplikaci.Chcete-li přistoupit k objektu Application, otevřete libovolný soubor s uživatelským kódem v editoru kódu a poté zadejte Application.Typy metod a vlastností, které se zobrazí v IntelliSense po zadání Application a poté „.“, se budou měnit v závislosti na souboru, ve kterém píšete kód.Ve většině případů lze použít vlastnost objektu Application k získání objektu, který reprezentuje aktuálního uživatele.

Pracovní prostor dat

Objekt DataWorkspace je objekt nejvyšší úrovně pro veškerý datový přístup.Objekt DataWorkspace obsahuje vlastnost pro každý zdroj dat v projektu.Například, máte-li zdroj dat s názvem NorthwindData, LightSwitch vytvoří vlastnost s názvem NorthwinddData.Po zadání DataWorkspace v editoru kódu bude v rozevíracím seznamu k dispozici vlastnost NorthwindData.

Následující obrázek ukazuje některé generovaného členy, které se zobrazují v rozevíracím seznamu.

Vlastnosti objektu DataWorkspace zdroje dat

Zdroj dat

Aplikace LightSwitch vytvoří objekt pro každý zdroj dat v projektu.Tento objekt obsahuje členy, které lze použít pro přístup k datům.Členové objektu zdroje dat zahrnují vlastnosti sady entit a metody dotazu.

Následující obrázek znázorňuje některé generované členy, kteří se mohou zobrazit v rozevíracím seznamu.

Členy objektu zdroje dat

Vlastnosti sady entit

Vlastnost sady entit vrátí kolekci entit.Aplikace LightSwitch vytvoří vlastnost sady entit pro každou entitu ve zdroji dat.Pokud například váš zdroj dat obsahuje entitu s názvem Customer, aplikace LightSwitch vygeneruje vlastnost s názvem Customers.Pomocí vlastnosti Customers můžete získat objekt EntitySet, který představuje kolekci entit Customer.

Objekt EntitySet také obsahuje členy, kteří umožňují kontrolovat, zda má aktuální uživatel oprávnění ke čtení, aktualizaci nebo odstraňování entit v kolekci.Další informace naleznete v tématu Provádění úloh souvisejících s daty pomocí kódu.

[!POZNÁMKA]

EntitySet je jedním z několika typů objektů kolekce entit.Chcete-li optimalizovat výkon kódu, přesvědčte se, zda používáte správný typ objektu kolekce entit pro typ obchodní logiky, kterou píšete.Další informace naleznete v tématu Objekty kolekcí entit a výkon.

Metody dotazů

Metoda dotazu získá výsledky dotazu.Aplikace LightSwitch generuje metodu pro každý dotaz, který je definován ve zdroji dat.Název metody odpovídá názvu dotazu.Dotaz může vracet jedinou entitu nebo kolekci entit typu IDataServiceQueryable.

[!POZNÁMKA]

IDataServiceQueryable<T> je jedním z několika typů objektů kolekce entit.Chcete-li optimalizovat výkon kódu, přesvědčte se, zda používáte správný typ objektu kolekce entit pro typ obchodní logiky, kterou píšete.Další informace naleznete v tématu Objekty kolekcí entit a výkon.

Ve výchozím nastavení LightSwitch generuje následující metody dotazu pro každou entitu ve zdroji dat.

  1. < název entity >_Jednoduchá.

  2. < název entity >_SingleOrDefault.

Obě tyto metody přijmou segment primárního klíče a vrátí objekt s jedinou entitou.Pokud jsou vráceny žádné entity, < název Entity >_Jednoduchá metoda vyvolá výjimku, že < název Entity >_SingleOrDefault metoda vrátí hodnotu Null hodnotu (Nothing v jazyce Visual Basic).

Entity

Aplikace LightSwitch generuje EntityObject pro každou entitu v kolekci entit.Pokud by například váš kód načetl kolekci objednávek, kolekce by obsahovala objekt EntityObject představují jednotlivé objednávky.EntityObject obsahuje členy, pomocí kterých lze odstranit entitu, číst nebo aktualizovat hodnotu vlastností entity nebo získat související entity.Můžete získat EntityObject z objektu kolekce entit jako objekt EntitySet nebo pomocí volání metody dotazu, která vrátí entitu.Další informace naleznete v tématu Provádění úloh souvisejících s daty pomocí kódu.

Následující obrázek znázorňuje členy entity Order s názvem myOrder.Entita Order obsahuje vlastnosti entity, například OrderDate, OrderID nebo Freight.Entita Order má také členy, které můžete použít k získání související kolekce Order_Details, a Customer, který zadal objednávku.

Vlastnostmi objektu Entity

V tomto příkladu vrátí vlastnost Customer entitu Customer.Entita Customer je v relaci Customer-Order na jedné straně.

Vlastnost Order_Details vrací kolekci entit Order_Details.Entita Order_Details je v relaci Order-Order_Details na straně N.Objekt kolekce Order_Details je typu EntityCollection.

Tento obrázek také ukazuje vlastnost s názvem Order_DetailsQuery.Vlastnosti, které končí slovem Query vrátí objekt IDataServiceQueryable.

[!POZNÁMKA]

EntityCollection a IDataServiceQueryable jsou typy objektů kolekce entit.Chcete-li optimalizovat výkon kódu, přesvědčte se, zda používáte správný typ objektu kolekce entit pro typ obchodní logiky, kterou píšete.Další informace naleznete v tématu Objekty kolekcí entit a výkon.

Objekty kolekcí entit a výkon

Použijete-li ve výrazu LINQ objekt kolekce entit, aplikace LightSwitch provede operaci, která načte entity ze serverové vrstvy.Typ objektu, který použijete, určuje, zda aplikace LightSwitch načte všechny entity v kolekci, nebo pouze jejich podmnožinu.Chcete-li zajistit, aby se kód choval podle očekávání, zvolte nejvhodnější typ objektu kolekce pro obchodní logiku, kterou píšete.Existují dva typy objektů kolekce entit: objekty, které způsobí, že aplikace LightSwitch vyhodnotí výraz LINQ vzdáleně, a objekty, které způsobí, že aplikace LightSwitch vyhodnotí výraz LINQ místně.

Operace LINQ: Vzdálené vs.Místní spuštění

Používáte-li ve výrazu LINQ objekt EntitySet nebo IDataServiceQueryable, předá LightSwitch celý výraz LINQ datové službě serverové vrstvy.Výsledky výrazu jsou poté předány zpět do volajícího kódu.Pomocí tohoto typu spuštění dotazu lze dosáhnout dobrých výsledků, protože volajícímu kódu jsou vráceny pouze entity, které vyhovují dotazu.Datová služba však podporuje pouze podmnožinu operátorů dotazu.Pokud výraz vyžaduje další operátory LINQ, zvažte použití jiného typu objektů kolekce.

Následující obrázek znázorňuje výraz LINQ, který používá objekt IDataServiceQueryable.Tento příklad ukazuje operaci LINQ předávající datové službě celý výraz a vracející pouze entity Order, které vyhovují podmínkám dotazu.

Vzdálené spuštění výrazu dotazu

Používáte-li ve výrazu LINQ objekt EntityCollection nebo IEnumerable, nepředá LightSwitch výraz datové službě.Místo toho aplikace LightSwitch načte všechny entity daného typu.Výraz poté platí místně pro celou kolekci.Pokud je kolekce entit rozsáhlá, může tento typ spouštění dotazu negativně ovlivnit výkon.V kódu však lze používat úplnou sadu operátorů LINQ.Kromě toho může mít tento přístup smysl, když budete chtít předat celé kolekce entit jiným metodám v kódu.

Následující obrázek znázorňuje výraz LINQ, který používá objekt EntityCollection.Tento příklad ukazuje operaci LINQ načítající všechny entity Order konkrétního zákazníka.Podmínky dotazu poté platí pro celou kolekci místně.

Místní spuštění výrazu dotazu

Příklady: Získání objektů kolekce entit v kódu

Následuje ukázka způsobu získání kolekcí entit Order v ukázkové databázi Northwind.

Chcete-li získat tento objekt kolekce entit

Použít tento kód

Vzdálené nebo místní spuštění

EntitySet

DataWorkspace.Northwind.Orders

or

myOrder.Details.EntitySet()

Vzdálené

IDataServiceQueryable

myCustomer.OrdersQuery

or

DataWorkspace.Northwind.Orders.GetQuery()

Vzdálené

EntityCollection

myCustomer.Orders

Místní

IEnumerable

myCustomer.OrdersQuery.Execute()

or

DataWorkspace.Northwind.Orders.GetQuery().Execute()

Vzdálené

Viz také

Koncepty

Provádění úloh souvisejících s daty pomocí kódu

Další zdroje

Data: Informace pro vaši aplikaci