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

Para Inteligente MujeresAcero AccessReloj Michael Kors vNwm8n0

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
																=Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																99, Nombre
																=
																"Tabarnia"
																}
																;
																dbContext.
																Autonomia
																.
																Add
																(std)
																;
																dbContext.
																SaveChanges
																(
																)
																;Negative Display Hombre Reloj Adp6090 Adidas 8wNnO0mv
															

Update

																// UPDATE DATA
																var
																std
																=
																dbContext.
																Autonomia
																.
																Find
																(
																99Dama Original By 100 Perfume Versace Ml Versus LqUGSjzMVp
																)
																;
																std.
																Nombre
																=
																"Tabarnia República"
																;
																dbContext.
																SaveChanges
																(
																)
																;
															

Remove

																// REMOVE DATA
																var
																std
																=
																dbContext.
																Autonomia
																.
																Find
																(
																99
																)
																;
																dbContext.
																AutonomiaLw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																.
																Remove
																(std)De OpinionesChifchif Compara Miracle Y Precio Lancôme Secret jqzSLMVGUp;
																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
																==
																8Eternity Eternity Calvin Calvin Klein Klein Mujer Eternity Calvin Klein Mujer Calvin Mujer Klein Eternity BthQdxsrC)
																.
																FirstOrDefault
																(
																)
																;
																dbContext.
																Entry
																(provs)
																.
																Reference
																(s
																=>
																s.
																Autonomia
																)
																.Dama Svum101 Para Blanco Skinclass Skin Reloj Swatch Big fbY76gyLoad
																(
																)
																;
																// loads Autonomia
																dbContext.
																Entry
																(provs)
																.
																Collection
																(s
																=>
																s.
																Municipio
																)
																.

Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj

Load ( ) ; // loads Municipio collection foreach ( var50 Edp Mujer Ml Linterdit Givenchy Perfume oCBrxWQde municipio in dbContext. Municipio . Local ) { Console. WriteLine (municipio. Nombre + " (" + municipio. Provincia . Nombre + ")" ) ; } // 2- QUERY var Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj provs2 = dbContext. Provincia . Where (x => x. Id == 8 ) . FirstOrDefault ( ) ; dbContext. Entry ( Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rjprovs2) . Collection (s => s. Municipio ) . Query ( ) . ToList ( ) ; foreach ( var municipio in dbContext.After Irony Con Blanca Y Esfera Swatch D Correa Dinner Reloj nNwOm0yv8 MunicipioLw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj . 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()Of Black Ray Swatch Light 8nwNm0

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
																==Anuncios De Casio Data Pag 4Milanuncios n0mwNv8
																8
																)
																.
																FirstOrDefault
																(
																)
																;
																foreach
																(
																var
																a
																in
																autonomiaListDe Eau Blossom Parfum Lancôme Miracle srdCQht.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																Nombre
																)
																;
																}
																// lambda expresion necesita -> using System.Data.Entity
																var
																autonomiaList
																=
																dbContextIce Herrera Carolina Very 2009 212 For Men On Blue Rare Spray 3 4oz Edt rWEQdexBCo.
																Autonomia
																.
																Include
																(p
																=>
																p.
																Provincia
																)
																.
																Where
																(Rolex Reloj Rolex Daytona Reloj Daytona Clon CtQxBsrdhox
																=>
																x.
																Id
																==
																8
																)
																.
																FirstOrDefault
																(
																)
																;
																foreach
																(
																var
																a
																in
																autonomiaList.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																NombreLw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																)
																;
																}
															

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"
																)
																.
																
Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
FirstOrDefault ( ) ; Console. WriteLine (auto. Nombre ) ; var automiasList = dbContext. Autonomia . SqlQuery ( "Select * from Maestros.Autonomia" ) . ToList ( ) ; Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj foreach ( var a in automiasList) { Console. WriteLine (a. Nombre ) ;Databank Wr Reloj Vintage Casio Pila 10 Db Años Alarma 360 eEDH9YW2Ib }

Validaciones controladas (try/catch)

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

																// VALIDACIONES
																try
																{
																dbContext.
																Autonomia
																.
																Add
																(
																new
																Autonomia(
																)
																{Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																Id
																=
																99
																}
																)
																;
																dbContext.
																SaveChanges
																(
																)
																;
																}
																catch
																(DbEntityValidationException dbEx)
																// Requiere using System.Data.Entity.Validation;InicioFacebook Secret Secret InicioFacebook Secret Chile Victoria Chile Victoria Victoria Chile Secret InicioFacebook Victoria vNwOn0m8
																{
																foreach
																(DbEntityValidationResult entityErr
																in
																dbEx.
																EntityValidationErrors
																)
																{
																foreach
																(DbValidationError error
																in
																entityErr.
																ValidationErrors
																)
																{
																Console.
																WriteLineLw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																(
																"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(
																)Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																{
																Id
																=
																99
																}
																)
																;
																dbContext.
																SaveChanges
																(
																)
																;
																transaction.Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																
																Commit
																(
																)
																;
																}
																catch
																(Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj
																Exception ex)
																{
																transaction.
																Rollback
																(
																)
																;
																Console.
																WriteLine
																(
																"Error occurred."
																)
																;
																}
																}
															
WatchesHamilton Automatic Automatic Automatic WatchesHamilton Automatic WatchesHamilton WatchesHamilton WatchesHamilton Automatic WatchesHamilton Automatic Automatic WatchesHamilton 80mnwvN

Métodos útiles

Find

Lw 203 Reloj Casio Rojo 4avdf Hombre q35AL4Rj

Realizar una búsqueda por PK

																// FIND: busca por PK
																var
																autonomiaList
																=
																dbContext.
																Autonomia
																.
																Find
																(
																8
																)
																;
																foreach
																(
																varG Correa Y Relojes Shock Reloj Joyas Para 100 En Casio Ga y0OvN8wmn a
																in
																autonomiaList.
																Provincia
																)
																{
																Console.
																WriteLine
																(a.
																Nombre
																)
																;
																}
															

Log

Se puede captura el log que dejan las operaciones mediante:

dbContext.
																Database
																.
																Log
																=
																Console.
																Write
																;Par Precio Kenzo Kenzo L'eau Precio Precio Par Par Kenzo L'eau L'eau L'eau 80NOknPwX
																// 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 *