Excel ODBC - Общее "Как это работает?"
Думая о перемещении нескольких связанных электронных таблиц в модель базы данных. Тем не менее, у меня есть много нетехнических применений, которые едва могут использовать Excel, но о том, что они используют что-то вроде MS Access, не может быть и речи. (или OOBase/MySQL, поскольку у нас нет MS Access)
Я хочу сохранить Excel в качестве основного пользовательского интерфейса для отчетов и думал об использовании ODBC-соединений для этого, но я не использовал его раньше и задавался вопросом, подходит ли он.
Если я создаю запрос, импортирую данные в файл Excel и сохраняю... данные постоянны? Будет ли он сохраняться после закрытия и открытия файла или пользователям придется каждый раз выбирать запрос?
Могу ли я использовать его в качестве источника для диаграмм Excel (не сводных) и легко ли автоматизировать аналогично обычным таблицам Excel с помощью структурированных ссылок?
Могу ли я легко добавить таблицу Excel для вычисляемых столбцов, основанных на данных базы данных, или было бы лучше включить такие вычисления в саму модель базы данных?
Я так понимаю запросы только для чтения? Есть ли возможный способ ввода данных для записи в базу данных с использованием Excel, а не формы в СУБД? Чем проще, тем лучше для конечных пользователей.
Сами файлы базы данных будут храниться в общей сети. Нужно ли мне что-то настраивать / устанавливать на каждом локальном компьютере, чтобы они могли получить доступ к данным? (все машины уже имеют Excel)
1 ответ
Excel хранит копию запрашиваемых данных в электронной таблице. Вы можете установить опцию, хотите ли вы, чтобы она обновлялась при загрузке, или только после некоторого ручного вмешательства или события на основе VBA.
Вы можете использовать данные запроса Excel так же, как и любые другие данные в Excel. В самом худшем случае, если есть какое-то ограничение, вы можете скопировать запрошенные данные на новый лист и "Вставить значения", чтобы разорвать связь с запросом.
Нужно ли делать вычисляемые столбцы локально или на базе данных, зависит от ваших потребностей в производительности. С одной стороны, некоторые вычисления можно сделать более эффективно на выделенном сервере базы данных с высококлассными спецификациями и оптимизированным механизмом SQL (ODBC в Excel определенно не таков, поверьте мне). С другой стороны, если вы хотите, чтобы тысячи клиентов обращались к БД, вы можете столкнуться с ограничениями ЦП или пропускной способности, если вы добавите много дополнительных данных для передачи, особенно если у вас нет особенно быстрого восходящего соединения. между клиентами и БД. Таким образом, вы можете захотеть, чтобы каждая рабочая станция клиента выполняла вычисляемые поля, что распределяет нагрузку между всеми клиентами и уменьшает объем данных, передаваемых по сети. Однако Excel не так эффективен в обработке данных огромного масштаба, как выделенные базы данных. Ответ "это зависит".
Сам механизм "Microsoft Query" в Excel может не выполнять запросы на обновление / вставку, но вы можете написать макрос VBA или надстройку C#, которая использует ADO для запуска произвольного SQL с бэкэндом.
Это полностью зависит от того, какую базу данных вы выберете. Вы упомянули Access, OOBase (я даже не уверен, что это будет работать вообще) и MySQL. Access имеет встроенный драйвер ODBC в любой системе, в которой установлен Access. MySQL должен иметь собственный драйвер ODBC MySQL, установленный в каждой клиентской системе. Большинству других баз данных также потребуется установить какой-либо драйвер ODBC в системе, если только вам не повезет, и в БД, которую вы хотите использовать, есть встроенный драйвер, уже поставляемый с Windows.