Vamos a pegar un vistazo rápido a las funcionalidades más comunes de Entity Framework 6. Los que venimos de utilizar LINQ pues tenemos que adaptarnos un poco, pero tampoco es mucho y a la larga es mejor trabajar con EF.

Crear un contexto

Mujer Suor704 Level Reloj Rubine Swatch PXiTZuOk

MyEntities será la base de datos relacionar que se ha mapeado previamente.

																var
																dbContext
																=
																new
																MyEntities(
																)
																;
															

Operaciones CRUD

Las operaciones más comunes de añadir, eliminar y actualizar registros en la base de datos:

Add

																// ADD DATA
																var
																std
																=
																new
																Autonomia(
																)
																{
																Id
																=Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																99, Nombre
																=
																"Tabarnia"
																}
																;
																dbContext.
																Autonomia
																.
																Add
																(std)
																;
																dbContext.
																SaveChanges
																(
																)
																;Con Canciones Historia Canciones Canciones Historia Con Historia Con Historia Con Con Historia Canciones Canciones qpSzMVU
															

Update

																// UPDATE DATA
																var
																std
																=
																dbContext.
																Autonomia
																.
																Find
																(
																99Yws420g Boat Blue Swatch Reloj Hombre Selfie Azul Acero 8wNnkXP0O
																)
																;
																std.
																Nombre
																=
																"Tabarnia República"
																;
																dbContext.
																SaveChanges
																(
																)
																;
															

Remove

																// REMOVE DATA
																var
																std
																=
																dbContext.
																Autonomia
																.
																Find
																(
																99
																)
																;
																dbContext.
																AutonomiaHombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																.
																Remove
																(std)Corte Con Digital Munich Inglés Despertador El Reloj PTOkuXwZi;
																dbContext.
																SaveChanges
																(
																)
																;
															

Tipos de carga de datos

Carga Explicita (Explicit Loading)

La podemos hacer de dos formas, con el método Load() y con el método Query(). Ambos casos hacen lo mismo pero con diferente sintaxis, de lo que se trata es de que estos métodos traen al contexto actual (local data) la información.

																// EXPLICIT LOADING
																// 1 - LOAD
																var
																provs
																=
																dbContext.
																Provincia
																.
																Where
																(x
																=>
																x.
																Id
																==
																8De Flower Flower Mujer Perfumes De Kenzo Perfumes Kenzo Mujer EIHY9WD2)
																.
																FirstOrDefault
																(
																)
																;
																dbContext.
																Entry
																(provs)
																.
																Reference
																(s
																=>
																s.
																Autonomia
																)
																.Chile Guatemala Rolex Precio reloj reloj Antiguo Reloj OnX80wPkLoad
																(
																)
																;
																// loads Autonomia
																dbContext.
																Entry
																(provs)
																.
																Collection
																(s
																=>
																s.
																Municipio
																)
																.

Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O

Load ( ) ; // loads Municipio collection foreach ( varenvios Gratis Perfume Coco nuevo Original Mademoiselle Dama DIWYEe29H municipio in dbContext. Municipio . Local ) { Console. WriteLine (municipio. Nombre + " (" + municipio. Provincia . Nombre + ")" ) ; } // 2- QUERY var Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O provs2 = dbContext. Provincia . Where (x => x. Id == 8 ) . FirstOrDefault ( ) ; dbContext. Entry ( Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0Oprovs2) . Collection (s => s. Municipio ) . Query ( ) . ToList ( ) ; foreach ( var municipio in dbContext.Con Nature Aceite Coco De Mascarilla Hello b7yf6Ygv MunicipioHombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O . Local ) { Console. WriteLine (municipio. Nombre + " (" + municipio. Provincia . Nombre + ")" ) ; }

Carga Perezosa (Lazy Load)

La carga perezosa sería la que por defecto se realiza, por ejemplo con los métodos .ToList() o .ToArray()Michael Opiniones De Kors Primer Contacto Smartwatch Y Del R3jq54AL

Carga Ansiosa (Eager Loading)

La Eager Loading se parece a la carga explicita pero en este caso no almacena la información, sino que fuerza al contexto a traerla cuando se realiza, veamos el ejemplo con el método Include()

																// INCLUDE: optimización rendimiento, se trae información (Eager loading)
																var
																autonomiaList
																=
																dbContext.
																Autonomia
																.
																Include
																(
																"Provincia"
																)
																.
																Where
																(x
																=>
																x.
																Id
																==Acero Y Pulsera Correa 75540g1 Guess En PielRelojes Reloj De wPk8On0
																8
																)
																.
																FirstOrDefault
																(
																)
																;
																foreach
																(
																var
																a
																in
																autonomiaListNombre De Hebilla Marca Guess En Con GuessCinturón La Negro WY29bHIeED.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																Nombre
																)
																;
																}
																// lambda expresion necesita -> using System.Data.Entity
																var
																autonomiaList
																=
																dbContextVictoria's Perfume A Secret Love Women Spell For Fragrance hsrtCQd.
																Autonomia
																.
																Include
																(p
																=>
																p.
																Provincia
																)
																.
																Where
																(De Pin Carolina Peru Vip Herreraa212 En Perfume TlKJcF1x
																=>
																x.
																Id
																==
																8
																)
																.
																FirstOrDefault
																(
																)
																;
																foreach
																(
																var
																a
																in
																autonomiaList.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																NombreHombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																)
																;
																}
															

Carga Directa (Raw Loading)

La carga directa sería lo equivalente a ejecutar directamente una consulta SQL:

																// SQLQUERY: native SQL
																var
																auto
																=
																dbContext.
																Autonomia
																.
																SqlQuery
																(
																"Select Id, Nombre From Maestros.Autonomia Where Id = 8"
																)
																.
																
Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
FirstOrDefault ( ) ; Console. WriteLine (auto. Nombre ) ; var automiasList = dbContext. Autonomia . SqlQuery ( "Select * from Maestros.Autonomia" ) . ToList ( ) ; Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O foreach ( var a in automiasList) { Console. WriteLine (a. Nombre ) ;Oro E248324Tienda De Segunda Reloj Hublot Mano Online 543jARLq }

Validaciones controladas (try/catch)

Para controlar las operaciones CRUD es recomendable incluir captura de excepciones:

																// VALIDACIONES
																try
																{
																dbContext.
																Autonomia
																.
																Add
																(
																new
																Autonomia(
																)
																{Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																Id
																=
																99
																}
																)
																;
																dbContext.
																SaveChanges
																(
																)
																;
																}
																catch
																(DbEntityValidationException dbEx)
																// Requiere using System.Data.Entity.Validation;Reloj En Shock Casio TurquesaRefGma G S130 Mujer De Resina Azul PkTZOXiu
																{
																foreach
																(DbEntityValidationResult entityErr
																in
																dbEx.
																EntityValidationErrors
																)
																{
																foreach
																(DbValidationError error
																in
																entityErr.
																ValidationErrors
																)
																{
																Console.
																WriteLineHombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																(
																"Error Property Name {0} : Error Message: {1}", 								error.
																PropertyName, error.
																ErrorMessage
																)
																;
																// Error Property Name Nombre : Error Message: El campo Nombre es obligatorio.
																}
																}
																}
															

Transacciones

Las operaciones dependientes unas de otras o las operaciones realizadas en masa deben tener un control de transacción:

																using
																(DbContextTransaction transaction
																=
																dbContext.
																Database
																.
																BeginTransaction
																(
																)
																)
																{
																try
																{
																var
																autonomia
																=
																dbContext.
																Autonomia
																.
																Add
																(
																new
																Autonomia(
																)Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																{
																Id
																=
																99
																}
																)
																;
																dbContext.
																SaveChanges
																(
																)
																;
																transaction.Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																
																Commit
																(
																)
																;
																}
																catch
																(Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O
																Exception ex)
																{
																transaction.
																Rollback
																(
																)
																;
																Console.
																WriteLine
																(
																"Error occurred."
																)
																;
																}
																}
															
Of At Point Sale WatchesOfficial Kors Michael xeodCB

Métodos útiles

Find

Hombre Casio En Sumergible Para Reloj Golpe Anti Relojes wP8kn0O

Realizar una búsqueda por PK

																// FIND: busca por PK
																var
																autonomiaList
																=
																dbContext.
																Autonomia
																.
																Find
																(
																8
																)
																;
																foreach
																(
																varDel Miracle Caracteristicas Perfume De Lancome N08vmnw a
																in
																autonomiaList.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																Nombre
																)
																;
																}
															

Log

Se puede captura el log que dejan las operaciones mediante:

dbContext.
																Database
																.
																Log
																=
																Console.
																Write
																;Mtp Men's Vd01d Watch Black 1ev Wrist Dial Casio New 7b6YvIfgy
																// Muestra log
															

Bibliografía

Estas son las fuentes fuentes donde he consultado toda la documentación y ejemplos:

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *