Es una combinación de razones históricas / evolutivas y de fuerza de mercado
Mientras trabajaba en Microsoft hace algunos años, estaba claro que había varias ofertas de datos diferentes en desarrollo. Cada una de las ofertas estaba dirigida a un mercado o caso de uso en particular, por ejemplo:
El acceso estaba dirigido a usuarios de escritorio que se sienten cómodos con los sistemas de indexación de tarjetas que pueden crear aplicaciones utilizando los formularios e informes. SQL fue una adición natural. Todo esto usó su propio motor de base de datos de máquina local llamado 'JET'. Eventualmente, JET fue dejado de lado: la palabra en la vid era que la falta de control de fuente (confiable) significaba que habían perdido una gran parte de la fuente.
FoxPro estaba dirigido a usuarios de escritorio que querían velocidad sobre datos relacionales.
SQL Server era el sistema de base de datos 'grande' Enterprise / Server-side con toda la escala / potencia / disponibilidad, etc. que las empresas necesitan. IIRC, MS licencia una versión de Sybase 6 sobre la cual construir MSSQL.
Con el tiempo, algunos de los límites se han vuelto borrosos, por ejemplo, SQL Server puede ejecutarse en una máquina de escritorio ahora, pero el caso de uso se mantuvo.
Esto nos da 3 'back-end': productos de bases de datos producidos por Microsoft.
Para agregar a la mezcla, había diferentes niveles de API de desarrollador para obtener acceso a estos sistemas:
Inicialmente, no había mucho en el camino de las API: escribió su código dentro de la aplicación (FoxPro / Access). VBA fue un método.
Microsoft implementó MS ODBC para conectarse a sistemas competitivos para que Windows pueda comunicarse con grandes bases de datos como Oracle, Sybase, etc. Excel fue una de las aplicaciones notables para obtener herramientas ODBC: extraer datos de su gran base de datos, manipularla y gráficos de productos / gráficos, etc. Muchos proveedores de bases de datos terminaron implementando ODBC para permitir que clientes dispares se conectaran, por lo que esta estrategia fue exitosa ... hasta cierto punto, ODBC podría considerarse como la representación del mínimo común denominador.
Diferentes equipos comenzaron a producir sus propias formas de acceder a un motor de base de datos como DAO (Data Access Objects) para local y RDO (Remote Data Objects) para remoto, accesible a través de VB, que era el producto desarrollador de MS más popular en ese momento.
Un esfuerzo interno para racionalizar estas API diversas y proporcionar una API de acceso a la base de datos única / altamente flexible nos dio OLEDB, pero fue muy muy difícil entrar (muchas plantillas de C ++).
OLEDB no se pudo usar desde VB, por lo que ADO se desarrolló utilizando técnicas ActiveX, por lo que se volvió reutilizable por cualquier cosa que pudiera hacer COM / OLE / ActiveX, lo que significa que Access, Excel, VB y, por lo tanto, ASP se habilitaron para la base de datos.
A medida que avanzamos hacia la era .NET, ADO se trasladó naturalmente a un entorno .NET que trajo varios beneficios.
Con la llegada de LINQ, el mecanismo real de acceso a la base de datos se convirtió en un problema menor.
Advertencia: me fui hace un tiempo, así que mi memoria está un poco borrosa