Diferencia Entre ODBC Y ADO

Diferencia Entre ODBC Y ADO
Diferencia Entre ODBC Y ADO
Anonim

ODBC frente a ADO

Normalmente, las aplicaciones de software están escritas en un lenguaje de programación específico (como Java, C #, etc.), mientras que las bases de datos aceptan consultas en algún otro lenguaje específico de la base de datos (como SQL). Por lo tanto, cuando una aplicación de software necesita acceder a los datos de una base de datos, se requiere una interfaz que pueda traducir idiomas entre sí (aplicación y base de datos). De lo contrario, los programadores de aplicaciones deben aprender e incorporar lenguajes específicos de bases de datos dentro de sus aplicaciones. ODBC (Open Database Connectivity) y OLE DB (Object Linking and Embedding, Database) son dos interfaces que resuelven este problema específico. ODBC es una interfaz independiente de la plataforma, el idioma y el sistema operativo que se puede utilizar para este propósito. OLE DB es un sucesor de ODBC. ADO es un contenedor para OLE DB.

¿Qué es ODBC?

ODBC es una interfaz para acceder a los sistemas de gestión de bases de datos (DBMS). ODBC fue desarrollado por SQL Access Group en 1992 en un momento en el que no existía un medio estándar para comunicarse entre una base de datos y una aplicación. No depende de un lenguaje de programación específico o un sistema de base de datos o un sistema operativo. Los programadores pueden utilizar la interfaz ODBC para escribir aplicaciones que pueden consultar datos de cualquier base de datos, independientemente del entorno en el que se esté ejecutando o del tipo de DBMS que utilice.

Debido a que el controlador ODBC actúa como un traductor entre la aplicación y la base de datos, ODBC puede lograr la independencia del idioma y la plataforma. Esto significa que la aplicación se libera de la carga de conocer el idioma específico de la base de datos. En su lugar, solo conocerá y utilizará la sintaxis ODBS y el controlador traducirá la consulta a la base de datos en un idioma que pueda entender. Luego, los resultados se devuelven en un formato que la aplicación pueda entender. La API de software ODBC se puede utilizar con sistemas de bases de datos tanto relacionales como no relacionales. Otra ventaja importante de tener ODBC como middleware universal entre una aplicación y una base de datos es que cada vez que cambia la especificación de la base de datos, no es necesario actualizar el software. Solo una actualización del controlador ODBC sería suficiente.

¿Qué es ADO?

ADO es una colección de objetos COM (modo de objeto componente) que actúan como una interfaz para acceder a datos en fuentes de datos. ADO fue desarrollado en 1996 por Microsoft como parte de Microsoft Data Access Components (MDAC). ADO forma una capa de middleware entre las aplicaciones escritas en algún lenguaje de programación y OLE DB (una API de datos desarrollada por Microsoft y sucesora de ODBC). Los programadores pueden utilizar ADO para acceder a los datos sin conocer los detalles de implementación subyacentes de la base de datos. Aunque no es necesario que conozca SQL para usar ADO, ciertamente puede ejecutar instrucciones SQL usándolo.

¿Cuál es la diferencia entre ODBC y ADO?

ODBC es una interfaz abierta, que puede ser utilizada por cualquier aplicación para comunicarse con cualquier sistema de base de datos, mientras que ADO es un envoltorio de OLE DB (que es el sucesor de ODBC). Si la base de datos no admite OLE (entornos no OLE), ODBC es la mejor opción. Si el entorno no es SQL, entonces debe usar ADO (porque ODBC solo funciona con SQL). Si se requieren componentes de base de datos interoperables, entonces se debe utilizar ADO en lugar de ODBC. Sin embargo, para datos de 16 bits, el acceso a ODBC es la única opción (ADO no admite 16 bits). Finalmente, ADO es la mejor opción para conectarse a múltiples bases de datos a la vez (ODBC puede conectarse a una sola base de datos a la vez).