Diskuze: EF provolání procedury a zkopírování do entity
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Možná kdybys sem dal konkrétní příklad (kus kódu), při jakém dotazu to spadne, na co se v něm ptáš, co z něj vytahuješ atd., dalo by se lépe poradit...
Ahoj, co LINQ to SQL? (na data se optat přímo, ne pomocí procedury)
Dobře mám následující kód v proceduře.
SELECT SU_Sport.Name
SU_Sport.ID
from SU_Sport
Nekoukejte prosím na to, že je to jedoduché o to tu nejde. A následně
bych tento výstup chtěl zkopírovat do Entity Sport kde je ID,Name,DateCreate
atd. a nejde to hodí to tu chybu jak jsem psal víš. A můj jediný dotaz je
zda to vůbec nějak de nacpat do tý entity nebo si pro výstup z této
procedury musím udělat model.
Předem děkuji za odpověď.
A druhá odpověď ano přes linq by to šlo ale dělám to přes EF kde to taky de ale zrovna tady bych prostě potřeboval proceduru.
Ok,
a co EF, LINQ a anonymní třídy? V DbContextu máš nejspíš DbSet s názvem
SU_Sport. Můžeš se přeci přímo optat takto:
var dbc = new TvujDbContext();
var pouzeIDaNAME = dbc.SU_Sport.Select(x=>new { x.ID, X.Name}).ToList();
případně přidat nějakou omezující podmínku. Není přeci důvod používat procedury při čtení.
V této proceduře mám rekurzi. Chci to mít v proceduře, protože je to rychlejší.
No, to jsi ale vůbec nenapsal... leze to z tebe jak z chlupatý deky. A co zkusit View? Do definice view hodit tu tvoji rekurzi a namapovat v EF, případně si vygenerovat třídu podle View. ...nevím jestli teda používáš Code First nebo DB First.
Nevim co ze mě leze jak z chlupatý deky ale ok... Dal jsem jen jednoduchou otazku a ty si mi na ni nepdpovedel jenom mi furt davas alternativy. Moje otazka zni: kdyz mam proceduru muzu jeji vystup nejak napojit na entity model? Nebo pro to musí vytvořit zvlášť output model? (Vygenerovat) To je moje jedina otazka kterou uz jsem napsal dvakrat a ty si mi nejdriv napsal linq a pak view nevim co je na tom nesrozumitelnyho nic mene jsem pochopil ze je spise lepsi pouzit vlastni model - moznost pridat promenny co entity nema atd. Takze diky za odpovědi.
Promiň, já myslel že ti to došlo z chybové hlášky, class v C# musí odpovídat výstupní "tabulce". Pokud používáš DB First, pak ti EF (pokud si to samozřejmě zvolíš) vygeneruje do DbContextu i příslušné funkce pro procedury a pokusí se odvodit "model". Pokud nepoužíváš DB First, pak si musíš model udělat ručně.
Zobrazeno 9 zpráv z 9.