Я работаю над настольным приложением, которое должно (в настоящее время) поддерживать MS Access и SQL Server.Приложение находится в постоянной разработке, и в базу данных часто вносятся изменения, в основном это добавление таблиц и представлений для поддержки новых функций (а также некоторых DROP и ALTER TABLE для добавления новых столбцов).
У меня естьсистема, которая компилирует DDL в исполняемый файл, проверяет базу данных, чтобы увидеть, есть ли у исполняемого файла какой-либо новый DDL, который должен быть выполнен, и выполняет его.Это прекрасно работает для одной базы данных.
Моя непосредственная проблема заключается в том, что SQL Server и Access поддерживают дико разные имена для типов данных, поэтому оператор CREATE TABLE, выполняемый для Access, не будет выполняться для SQL Server (или, что еще хужевыполнить, но создать таблицу с разными типами данных).
Существует ли метод, который можно использовать для создания DDL (особенно команд CREATE TABLE), который можно выполнить через ADO для обеих этих баз данных без необходимости создания отдельного DDLдля каждого провайдера?