Hola haggenx, gracias por responder.
Efectivamente se puede usar mdb (estoy con C# .NET, no con VB.NET, pero en esto viene a ser lo mismo). El mismo código que encontré de ejemplo para usar con una base de datos accdb parece funcionar también perfectamente con mdb de Access 97 sin hacerle ningún cambio.
Por ejemplo, este es el método que uso para leer la tabla Clientes:
Código C#:
Ver originalpublic static Cliente[] ReadClients(string dataBasePath)
{
List<Cliente> result = new List<Cliente>();
string connectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + dataBasePath;
string queryString = "SELECT * FROM Clientes";
try
{
using (OleDbConnection connection = new OleDbConnection(connectionString))
{
OleDbCommand command = new OleDbCommand(queryString, connection);
connection.Open();
OleDbDataReader reader = command.ExecuteReader();
while (reader.Read())
{
Cliente readingClient = new Cliente();
int.TryParse(reader.GetValue(0).ToString(), out int id);
readingClient.Id = id;
readingClient.Nombre = reader.GetValue(1).ToString();
readingClient.Empresa = reader.GetValue(2).ToString();
readingClient.Dirección = reader.GetValue(3).ToString();
readingClient.Ciudad = reader.GetValue(4).ToString();
readingClient.Provincia = reader.GetValue(5).ToString();
readingClient.País = reader.GetValue(6).ToString();
readingClient.NIF = reader.GetValue(7).ToString();
readingClient.CodigoPostal = reader.GetValue(8).ToString();
readingClient.Teléfono = reader.GetValue(9).ToString();
readingClient.Fax = reader.GetValue(10).ToString();
readingClient.Email = reader.GetValue(11).ToString();
readingClient.Notas = reader.GetValue(12).ToString();
result.Add(readingClient);
}
reader.Close();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
return result.ToArray();
}
Muy importante que cualquiera que se encuentre en el mismo problema, que entienda claramente comandos SQL.
Esta página es muy buena para ello, incluso se pueden practicar ahí mismo con una base de datos de ejemplo:
https://www.w3schools.com/sql/sql_select.asp