Compartir vía


Información general sobre aplicaciones de datos de n niveles de .NET Framework

Nota:

Los conjuntos de datos y las clases relacionadas son tecnologías heredadas de .NET Framework de principios de la década de 2000 que permiten a las aplicaciones trabajar con datos en memoria mientras están desconectadas de la base de datos. Las tecnologías son especialmente útiles para las aplicaciones que permiten a los usuarios modificar los datos y conservar los cambios en la base de datos. Aunque los conjuntos de datos han demostrado ser una tecnología de gran éxito, se recomienda que las nuevas aplicaciones de .NET usen Entity Framework Core. Entity Framework proporciona una manera más natural de trabajar con datos tabulares como modelos de objetos y tiene una interfaz de programación más sencilla.

Las aplicaciones de datos de n niveles son aplicaciones de datos que se separan en varios niveles. Las aplicaciones con n niveles, también denominadas "aplicaciones distribuidas" o "aplicaciones multinivel", dividen el procesamiento en niveles independientes que se distribuyen entre el cliente y el servidor. Al desarrollar aplicaciones que tienen acceso a datos, se debe realizar una separación clara entre los distintos niveles que constituyen la aplicación.

Una aplicación típica con n niveles incluye un nivel de presentación, un nivel intermedio y una capa de datos. La manera más fácil de separar los distintos niveles de una aplicación con n niveles es creando proyectos independientes para cada nivel que se desee incluir en la aplicación. Por ejemplo, el nivel de presentación podría ser una aplicación de formularios Windows Forms, mientras que la lógica de acceso a datos podría ser una biblioteca de clases ubicada en el nivel intermedio. Además, es posible que el nivel de presentación se comunique con la lógica de acceso a datos del nivel intermedio a través de un servicio como un servicio web. Al separar los componentes de la aplicación en niveles independientes, se aumenta la facilidad de mantenimiento y la escalabilidad de la aplicación. Esto se consigue mediante una integración más sencilla de nuevas tecnologías, que se pueden aplicar a un solo nivel sin necesidad de volver a diseñar la solución completa. Además, las aplicaciones con n niveles almacenan normalmente la información confidencial en el nivel intermedio, lo cual mantiene su aislamiento respecto del nivel de presentación.

Visual Studio contiene varias características que ayudan a los programadores a crear aplicaciones con n niveles:

  • El conjunto de datos ofrece una propiedad DataSet Project que le permite separar el conjunto de datos (capa de entidad de datos) y TableAdapters (capa de acceso a datos) en proyectos adicionales.

  • Las Herramientas de LINQ to SQL en Visual Studio proporcionan valores para generar el objeto DataContext y las clases de datos en espacios de nombres independientes. Con ello se habilita la separación lógica del acceso a datos y los niveles de entidad de datos.

  • LINQ to SQL proporciona el método Attach que permite reunir el objeto DataContext de distintos niveles de una aplicación. Para obtener más información, vea Aplicaciones de n niveles y remotas con LINQ to SQL.

Nivel de presentación

El nivel de presentación es el nivel en el que los usuarios interactúan con una aplicación. Normalmente, contiene también la lógica adicional de la aplicación. Los componentes típicos del nivel de presentación son los siguientes:

  • Los componentes de enlace de datos, tales como BindingSource y BindingNavigator.

  • Representaciones de objeto de los datos, como las clases de entidad de LINQ to SQL para su uso en el nivel de presentación.

Normalmente, el nivel de presentación accede al nivel intermedio mediante una referencia de servicio (por ejemplo, una aplicación Servicios de Windows Communication Foundation y Servicios de datos de WCF en Visual Studio). El nivel de presentación no obtiene acceso directamente a la capa de datos. El nivel de presentación se comunica con la capa de datos por medio del componente de acceso a datos en el nivel intermedio.

Nivel intermedio

El nivel intermedio es la capa que el nivel de presentación y la capa de datos utilizan para comunicarse entre sí. Los componentes típicos del nivel intermedio son los siguientes:

  • La lógica empresarial (reglas empresariales, validación de datos, etc.).

  • La lógica y los componentes de acceso a datos, como los siguientes:

Las ilustraciones siguientes muestran las características y tecnologías que se encuentran disponibles en Visual Studio y dónde podrían integrarse en el nivel intermedio de una aplicación con n niveles.

Componentes de nivel intermedio

Nivel intermedio

El nivel intermedio se conecta normalmente con la capa de datos mediante una conexión de datos. Esta conexión de datos está almacenada normalmente en el componente de acceso a datos.

Nivel de datos

Básicamente, el nivel de datos es el servidor que almacena los datos de una aplicación (por ejemplo, un servidor que ejecuta SQL Server).

Las ilustraciones siguientes muestran las características y tecnologías que se encuentran disponibles en Visual Studio y dónde podrían integrarse en la capa de datos de una aplicación con n niveles.

Componentes de capa de datos

Nivel de datos

No se puede obtener acceso a la capa de datos directamente desde el cliente en el nivel de presentación. En su lugar, el componente de acceso a datos en el nivel intermedio se utiliza para la comunicación entre las capas de datos y la presentación.

Ayuda para el desarrollo con n niveles

En los temas siguientes se ofrece información sobre cómo trabajar con aplicaciones de n niveles.

Separar conjuntos de datos y TableAdapters en proyectos diferentes

Tutorial: Creación de una aplicación de datos de n niveles

Aplicaciones de n niveles y remotas con LINQ to SQL

Vea también