|
4 / 4 / 2
Регистрация: 13.11.2014
Сообщений: 108
|
||||||||||||||||||||||||||
Обновить заполненный DataTable из запроса select SQL23.09.2022, 17:59. Показов 792. Ответов 2
Собственно суть в заголовке, здесь лишь разжую немного.
Есть условная таблица на 100-400 тыс. записей находящаяся в бд (Firebird 2.5) на сервере в селе Хацапетовка связь с которым проходит через одно место и хорошо, если достигает 1Мб, НО стабильная что невозможно, содержащая по сути данные мониторинга. За которым нужно периодически хотя-бы следить и поглядывать. По самому оптимальному запросу получается около 60к. строк выборки при любом обновлении таблицы, т.е. там около 20 Мб летит по сети и ждёшь ты их под минут 5 точно. Таблице был пришпандорен триггер на поле lastUpdate, который при insert/update лепит туда текущее время. Ну и затея оптимизации состоит в том, чтоб в посылаемый select для поля lastUpdate выставлять условие последнего обновления таблицы на клиенте за 120 км. Ну и на клиенте я получаю соответственно обрезок данных, которые мне нужно соединить и обновить с уже имеющимися данными у меня на форме. По коду на форме имеем, что-то вроде такого: Кликните здесь для просмотра всего текста
DT_vwr.Load(fbcom.ExecuteReader()); //и вот на этом моменте я прям чёт затупил( Пробовал и со всевозможными параметрами LoadOption.OverwriteChanges и т.д., нет не то. Пробовал и через FbDataAdapter:
Первая загрузка норм. А потом уже когда данные имеются и их только обновить, то всё( вылетает только так: System.Reflection.TargetInvocationExcept ion: "Адресат вызова создал исключение" ...и здоровенный такой стек вызова. Понимаю, что это как-то проще должно делаться, но я чёт догнать никак не могу, затупил( Ключевые поля всякие пробовал устанавливать (а уникальные значения там есть) - не помогло( Гуглёж тоже не помогает, все тупо юзают новую таблицу и обновляет целиком ресы - а мне НЕ это надо! Мне существующую обновить надо. Можно конечно попробовать ручками foreach все дела, но тоже та ещё трында такое количество записей перебирать, хочется как-то более встроенными средствами обойтись, которые уже и без меня оптимизировали... а то я с этой оптимизацией уже повешусь скоро( Добавлено через 1 час 31 минуту ааааа это капец Нашёл решение вообще не там. Короче делает буферную таблицу грузите в неё данные.
![]() Добавлено через 5 минут а ну и в DT_vwr соответственно тоже ключевое указываете + отслеживаете первую загрузку и т.д. и т.п. ...как тут свой ответ пометить?) @moderator ?)
0
|
||||||||||||||||||||||||||
| 23.09.2022, 17:59 | |
|
Ответы с готовыми решениями:
2
Использовать значения запроса SELECT в t-sql
|
|
14147 / 9375 / 1351
Регистрация: 21.01.2016
Сообщений: 35,319
|
|
| 24.09.2022, 04:57 | |
|
КиберСталкер21, хоть вы вроде бы и нашли решение, но я всё равно хочу заметить, что DataTable и DataAdapter'ы - это пример из начала двухтысячных. Это морально устаревший механизм работы с СУБД и про него лучше забыть. Вам достаточно было создать класс описывающий выборку из базы и сформировать на его основе коллекцию. И ненадо никаких merge и Primary Key.
0
|
|
|
4 / 4 / 2
Регистрация: 13.11.2014
Сообщений: 108
|
|
| 24.09.2022, 09:10 [ТС] | |
|
Usaga, не переживайте, знаю, понимаю)
Просто я сейчас там разгребаю тонну костылей, в которых ещё и есть такие вещи, которые нужно оптимизировать до нельзя. А конкретно в этом ещё и участвует DevExpress на форме со своим ControlGrid в паре с gridView (в котором уже настроена кучка столбцов и перенастраивать которые бы не хотелось, т.к. там и checkbox'ы, и combobox'ы, и радужно-цветовое выделение и popupmenu, поиск и вообще чего только нет, короче там знатно прикололись), а к ним ещё и забиндена куча кнопок на форме тоже со своим "умопомрачительным" и спецефичным кодом и ломать их логику - это значит ломать пользователю мозг, а они этого не любят) Со временем то конечно всё будет переделано как надо, но на это уйдёт куча времени, а пользователям нужно оптимизировать было "ещё вчера", поэтому пока так.
0
|
|
| 24.09.2022, 09:10 | |
|
Помогаю со студенческими работами здесь
3
Как вывести результат запроса select в txt-файл? (Transact-SQL)
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+2) -. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|