|
0 / 0 / 0
Регистрация: 26.04.2025
Сообщений: 7
|
|
Медленно выполняется удалённая выборка31.05.2025, 16:36. Показов 1368. Ответов 7
Метки нет (Все метки)
Добрый день. Если кто может подскажите пожалуйста. Раньше была разделённая база Access, база (таблицы) висела в локальной папке и к ней локально были подключены интерфейсы с пользовательскими формами. Всё работало очень хорошо. Но со временем нужно было сделать удалённое подключение через VPN. Установил на сервер SQL Server 2022, экспортировал в него таблицы Access, с помощью ODBC Driver 18 for SQL Server и VBA установил связи базы с интерфейсов через туннель WireGuard. Все работает хорошо кроме одного. В базе имеется таблица, в ней 36000 записей. В интерфейсе есть поле например "Номер_удостоверения" Поиск нужной строки ведётся именно по этому полю. Включаю макрос "Найти запись" в окно ввожу например 0000456, данные находит за 3 секунды, а ввожу например 234765 данные программа ищет почти две минуты. Пробовал запрос штатный, писал на VBA, в SQL Server делал индексированное поле по которому ведётся поиск всё равно такая же ситуация. Одна мысль может VPN провайдеры прижимают или что то делаю не так. Хотя в самом SQL любая запись в таблице с помощью запроса появляется в секунды. Может что то подскажете
0
|
|
| 31.05.2025, 16:36 | |
|
Ответы с готовыми решениями:
7
Почему в ARCHIVELOG так медленно выполняется DDL? Медленно выполняется хранимая процедура Запрос на ASP выполняется медленно, чем на Management Studio |
|
13172 / 5869 / 1504
Регистрация: 05.10.2016
Сообщений: 16,488
|
||
| 31.05.2025, 16:42 | ||
|
А лучше всю форму + подключение к тестовой базе SQL Server.
0
|
||
|
0 / 0 / 0
Регистрация: 26.04.2025
Сообщений: 7
|
||||||
| 31.05.2025, 17:14 [ТС] | ||||||
И ещё я заметил, когда поле не было индексировано то номер 000001 программа искала 2 минуты а номер 0000070 3 секунды, но когда я поле проиндексировал 000001 нашелся за 3 секунды но номера 0126287 ищутся почти 2 минуты.
0
|
||||||
|
13172 / 5869 / 1504
Регистрация: 05.10.2016
Сообщений: 16,488
|
|||
| 31.05.2025, 17:39 | |||
|
... хм. вы прокачиваете по сети все данные таблицы пару раз точно. ![]() Это очень негативно сказывается на скорости. Используйте ADO, производя поиск на стороне сервера - будет шустро.
0
|
|||
|
0 / 0 / 0
Регистрация: 26.04.2025
Сообщений: 7
|
|
| 31.05.2025, 17:51 [ТС] | |
|
Спасибо. Попробую
0
|
|
|
913 / 287 / 57
Регистрация: 01.06.2023
Сообщений: 812
|
||
| 01.06.2025, 10:27 | ||
*...*. Попробуйте поиск без начальной звездочки (если позволяет бизнес логика), это приведек к префиксному поиску и тогда индекс возможно задействовать
0
|
||
|
0 / 0 / 0
Регистрация: 26.04.2025
Сообщений: 7
|
||||||
| 01.06.2025, 15:13 [ТС] | ||||||
|
Вот постарался по новому (напрямую подключиться, всё равно не то (5 записей ищет пять минут). То есть при первом запуске макроса через 3 секунды заполняются поля первыми данными первой записи и открывается сообщение что найдено 5 записей и вопрос "Показать следующую запись". Вот тут то и начинается интересное при нажатии на Да опять отправляется запрос поиска уже второй записи (как я понял по полю Код) и опять SQL начинает искать эту запись в таблице только по полю Код. Получается что разные запросы что бы получить пять значений я минимум раз шесть гоняю по интернету. Как бы сделать что бы один раз отправил запрос, SQL выбрал всё из таблицы и все данные отправил клиенту, тот только путём выбора выбрал нужную запись.
[01.06.2025 14:53:56] Начало выполнения макроса Поле для поиска: Фамилия Ищем значение: Иванов Пытаюсь подключиться к базе данных... Подключение успешно установлено Выполняю SQL запрос: SELECT * FROM База_охотников WHERE [Фамилия] = ? Найдено записей: 5 Обрабатываю запись Код: 41 (1/5) Отображаю запись Код: 41 Обрабатываю запись Код: 8929 (2/5) Отображаю запись Код: 8929 Обрабатываю запись Код: 20519 (3/5) Отображаю запись Код: 20519 Обрабатываю запись Код: 25204 (4/5) Отображаю запись Код: 25204 Обрабатываю запись Код: 32450 (5/5) Отображаю запись Код: 32450 Все записи просмотрены [01.06.2025 15:00:07] Завершение выполнения макроса. Общее время: 00:06:11 Может быть поле Код проиндексировать, а то 5 записей 6 минут - это много
0
|
||||||
|
Мы один, давай на "ты"
3849 / 1393 / 345
Регистрация: 16.06.2016
Сообщений: 3,288
|
|
| 01.06.2025, 16:11 | |
|
aleksandr76, Создание запроса к серверу
0
|
|
| 01.06.2025, 16:11 | |
|
Помогаю со студенческими работами здесь
8
Выборка из таблици товаров по самому максимальному рейтингу магазина, рейтинг мазаницов если есть одиноковые, выборка уже по минимальной цене
Выборка данных из нескольких таблиц. Аналитическая выборка данных Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|