Tengo un proyecto con varias clases diferentes que consultan y modifican datos en un conjunto común de tablas. Configuré un archivo .dbml que nos proporciona una clase DataContext. Mi pregunta es si una sola instancia de DataContext debería ser utilizada por todos los objetos, o si varias instancias son seguras de usar. También me pregunto sobre la seguridad de subprocesos en el caso de un solo DataContext, y si el acceso a sus métodos debe sincronizarse.Instancia múltiple/única de Linq a SQL DataContext
Respuesta
Rick Strahl tiene un buen artículo sobre sus opciones: http://www.west-wind.com/weblog/posts/246222.aspx.
Ver también: LINQ to SQL - where does your DataContext live?.
Es posible que desee una estrategia ligeramente diferente para cada tipo de despliegue - web, escritorio, servicio de ventanas ...
resumido, las opciones son:
- Global DataContext - peligroso de multiproceso entornos (incluidas las aplicaciones web). Recuerde que no se garantiza que los miembros de la instancia sean seguros para subprocesos (de Bradley Grainger's answer arriba).
- DataContext por hilo: complicado. Si su DataContext realiza un seguimiento de los cambios, debe asegurarse de eliminarlos en el momento apropiado. Instaurar, almacenar y recuperar el DataContext es un problema.
- DataContext por acción atómica: pierde la capacidad de seguir los cambios ya que un DataContext crea un objeto mientras que otro lo actualiza o lo elimina. Adjuntar un objeto de datos a un nuevo DataContext puede no funcionar como esperaba.
- DataContext por objeto de datos: parece poco elegante porque tiene que preocuparse por DataContext en la creación de instancias (crear y adjuntar) y actualizar/eliminar (sacarlo del objeto de datos y usarlo).
He optado por un DataContext por objeto de datos. Puede que no sea la solución más elegante, pero funciona en todos los entornos de implementación.
Siempre escuché que debería usar una sola instancia del DataContext. Por lo general, creo una instancia singleton de mi DC en mi clase de lógica de negocios y la utilizo para todas mis consultas de linq.
Estoy seguro de que algunos de los gurús de linq que están aquí podrían darte las razones exactas de por qué deberías tener solo una instancia de tu clase de contexto de datos ... No estoy seguro.
El problema con el uso de un único objeto de contexto de datos es que puede tener problemas si ha agregado algunos cambios a su cola, y desea realizar un roll-back en algunos de esos cambios en cola.
Es por eso que utilizo un objeto de contexto de datos para cada una de mis clases - mi clase User
tiene su propio contexto de datos, mi clase Application
tiene su propio y así sucesivamente.
Este patrón elimina la mayoría de los problemas de realizar retrotracción en mis proyectos.
La clase DataContext es lo suficientemente liviana para que pueda crear una instancia una y otra vez. Esto hace que todo sea más simple cuando se accede a objetos de entidad dentro de un único método. Si necesita acceder a los mismos objetos LINQ desde diferentes clases y métodos, manteniéndolos unidos a DataContext para realizar un seguimiento, también está bien mantener una sola instancia.
Utilizo una nueva instancia de DataContext para cada transacción.
La reutilización de instancias antiguas puede ser problemático e inflará el contenido del DataContext, ya que cualquier elemento que se haya cargado en algún momento deberá rastrearse: la aplicación se volverá lenta y lenta, lo que aumentará la memoria.
Si necesita un artículo más largo que para una transacción, puede separarlo del DataContext clonando el elemento, y puede volver a conectarlo más tarde a un nuevo y nuevo DataContext usando Adjuntar().
Incluso puedo clonar un artículo, enviarlo a través de la red con WCF, recuperarlo en una llamada posterior, adjuntarlo a un nuevo DataContext y guardar los cambios (por supuesto, necesito una columna de marca de tiempo para esto).
- 1. LINQ to SQL: ¿dónde vive su DataContext?
- 2. LINQ to SQL multiple DataContext-s
- 3. Cómo regenerar (actualizar) LINQ to SQL DataContext?
- 4. Cómo rastrear consultas en un DataContext Linq-a-sql
- 5. DataContext de Linq-to-SQL en varios subprocesos
- 6. Linq to Sql: ¿Puede la instancia de DataContext devolver colecciones que incluyen cambios pendientes?
- 7. adjuntando linq al sql datacontext a httpcontext en la capa empresarial
- 8. Inyectar la misma instancia DataContext en varios tipos con Unity
- 9. mediante ASP.NET MVC, LINQ to SQL y StructureMap causando DataContext a datos de la caché
- 10. ¿Hay un DataContext en LINQ-to-Entities (NO Linq-to-SQL)?
- 11. En LINQ-SQL, envolver el DataContext es una declaración utilizando - A favor En contra
- 12. ¿Linq a SQL o Linq a DataSet?
- 13. Depuración LINQ a SQL SubmitChanges()
- 14. Asociación LINQ a SQL Asignación
- 15. Linq ChangeConflictException se produce al enviar cambios de DataContext
- 16. ¿Cómo puedo obtener Ninject 2 para usar el constructor sin parámetros para LINQ to SQL DataContext?
- 17. ¿Cómo pasar de Linq 2 SQL a Linq 2 Entities?
- 18. ¿Cómo puedo rechazar todos los cambios en un Linq al DataContext de SQL?
- 19. ¿Hay un LINQPad equivalente a una clase DataContext?
- 20. Acceder al DataContext LINQ-2-SQL en la clase de entidad
- 21. C# LINQ to SQL - En caso de DataContext eliminarse utilizando IDisposable
- 22. LINQ to SQL e inmutabilidad
- 23. LINQ a SQL decimal Parámetro
- 24. Linq a SQL y teniendo
- 25. linq a sql comprobando nulo
- 26. Linq a SQL lambda join
- 27. Señales en Linq a Sql?
- 28. Convertir consulta SQL a LINQ
- 29. LINQ a SQL Ingreso cuestiones
- 30. ¿Cómo extiendes Linq a SQL?
Eso es vago y supersticioso. ¿Puedes ser más específico en cuanto a por qué tomaste este enfoque? –
Siempre escuché todo lo contrario. DataContexts tiene la intención de ser lo más efímero posible, con el fin de minimizar los problemas de simultaneidad. – Konamiman