Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/18: Рейтинг темы: голосов - 18, средняя оценка - 4.89
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41

Запрос по таймеру для обновления значений в гриде

13.10.2016, 09:09. Показов 3532. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Такой вопрос как организвать автоматическое обновление данных в гриде ? т е например по таймеру делать запрос к бд, но мне надо еще что бы если появились новые записи в бд либо произошли изменения в строках которые есть в запросе что бы об этом информировать пользователя и еще что бы показать пользователю где были изменения.

Добавлено через 15 секунд
БД MS Sql server
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.10.2016, 09:09
Ответы с готовыми решениями:

Запрос UPDATE для обновления БД с условием
Нужно составить запрос, чтобы он обновил нужную мне ячейку в БД, а именно, в таблице Заказ, столбец Код клиента, с таким условием, чтобы...

Запрос на сайт для обновления своих данных.
Проблема заключается в том, что необходимо все время обновлять данные на своем сайте, связанные с котировкой валют, для этого необходимо...

Запрос для удаления записи и обновления введенных (отредактированных) данных
Всем привет форумчане, помогите написать запрос для удаления записи и обновления введенных (отредактированных) данных. заранее всем...

14
4 / 4 / 1
Регистрация: 25.07.2016
Сообщений: 35
13.10.2016, 09:28
надо обновлять таблицу не по таймеру, а при конкретном изменении
0
 Аватар для virtual[ity]
165 / 143 / 66
Регистрация: 05.06.2010
Сообщений: 641
13.10.2016, 09:28
На уровне сервера должно это делаться. Хранимая процедура (Триггер) поможет.
0
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41
13.10.2016, 09:31  [ТС]
я просто не совсем понимаю как это сделать на урвне сервера, т е общение программы с сервером у меня так я с програмыы делаю запросы и сервер отвечает, а как тогда сделать что бы дефи слушало что говорит сервер ?
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
13.10.2016, 11:29
у вас сервер "вообще", и ответ вы получили "вообще"
что не устраивает?
0
 Аватар для MyEternity
97 / 97 / 25
Регистрация: 25.04.2016
Сообщений: 525
13.10.2016, 22:11
Цитата Сообщение от alextolmy Посмотреть сообщение
я просто не совсем понимаю как это сделать на урвне сервера, т е общение программы с сервером у меня так я с програмыы делаю запросы и сервер отвечает, а как тогда сделать что бы дефи слушало что говорит сервер ?
Делфи не слушает.
Делфи просто смотрит в нужную таблицу и все.

1. Добавьте к своей таблице timestamp (хотя правильнее добавить туда binary(8) например, и хранить timestamp в нем, обслуживая его формирование триггером).
2. В делфи при ПЕРВОМ заполнении dbGrid запоминайте последний timestamp.
3. При последующих запросах анализируйте по timestamp записи, которые у вас имеют более новую версию. (Да-да, это именно то, что изменилось).
0
пофигист широкого профиля
4769 / 3204 / 862
Регистрация: 15.07.2013
Сообщений: 18,612
14.10.2016, 01:15
Цитата Сообщение от alextolmy Посмотреть сообщение
Такой вопрос как организвать автоматическое обновление данных в гриде ?
А нафига?
Спрашиваю не просто "с балды". А просто знаю действительно нужное требование обновление DBGrida в реальном времени.
0
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41
14.10.2016, 05:43  [ТС]
Цитата Сообщение от MyEternity Посмотреть сообщение
Делфи не слушает.
Делфи просто смотрит в нужную таблицу и все.
1. Добавьте к своей таблице timestamp (хотя правильнее добавить туда binary(8) например, и хранить timestamp в нем, обслуживая его формирование триггером).
2. В делфи при ПЕРВОМ заполнении dbGrid запоминайте последний timestamp.
3. При последующих запросах анализируйте по timestamp записи, которые у вас имеют более новую версию. (Да-да, это именно то, что изменилось).
в таком варианте я так понимаю в любом случае по таймеру надо делать запрос и сравнивать по этому значению и если оно изменилось то обновляем грид, я правильно понял ? все изменения в базе делаются с помощью хп мб проще просто добавить это в хп на изменение ?

Добавлено через 2 минуты
Цитата Сообщение от northener Посмотреть сообщение
А нафига?
Спрашиваю не просто "с балды". А просто знаю действительно нужное требование обновление DBGrida в реальном времени.
Есть заявки, у них меняеться статус его надо отслеживать пользователям. с последующим уведомлением о том что произошли изменения в заявке и какие изменения произошли.

Добавлено через 50 секунд
Цитата Сообщение от krapotkin Посмотреть сообщение
у вас сервер "вообще", и ответ вы получили "вообще"
что не устраивает?
Цитата Сообщение от alextolmy Посмотреть сообщение
БД MS Sql server
что значит вообще ? все указанно !
0
4 / 4 / 1
Регистрация: 25.07.2016
Сообщений: 35
14.10.2016, 07:17
надо еще что бы если появились новые записи в бд либо произошли изменения в строках которые есть в запросе что бы об этом информировать пользователя и еще что бы показать пользователю где были изменения.
как информировать пользователя об изменениях?
0
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41
14.10.2016, 07:38  [ТС]
Цитата Сообщение от v90376 Посмотреть сообщение
как информировать пользователя об изменениях?
в гриде покрасить строки где произошли изменения, и всплывающие окно еще сделать. т е если мы обновляем таблицу то в сообщение будет просто уведомление об изменениях
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
14.10.2016, 09:06
есть две стратегии обновлений
запросы и уведомления
выбор стратегии зависит от частоты обновлений и объема передаваемый информации
если обновления случаются часто, то при выборе стратегии уведомлений перед нами может оказаться анимационная картина с ползущими строчками. и даже попасть в эти строчки проблематично. кроме того вся сеть лежит, непрерывно передавая данные. обновления грида тоже не самая бесплатная операция, поэтому комп будет все время "занят", перерисовывая экран
в этом случае лучше выбрать стратегию запросов, чтобы обновления происходили не чаще чем раз в N секунд
при этом подходе мы можем положить сеть и сервер большим количеством пользователей, т.к. он постоянно будет всем слать одно и то же по запросам.

вообще использование DBGrid и других DB-компонентов при непрерывном обновлении мне кажется не очень удачным
0
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41
14.10.2016, 09:08  [ТС]
ы
Цитата Сообщение от krapotkin Посмотреть сообщение
есть две стратегии обновлений
запросы и уведомления
выбор стратегии зависит от частоты обновлений и объема передаваемый информации
если обновления случаются часто, то при выборе стратегии уведомлений перед нами может оказаться анимационная картина с ползущими строчками. и даже попасть в эти строчки проблематично. кроме того вся сеть лежит, непрерывно передавая данные. обновления грида тоже не самая бесплатная операция, поэтому комп будет все время "занят", перерисовывая экран
в этом случае лучше выбрать стратегию запросов, чтобы обновления происходили не чаще чем раз в N секунд
при этом подходе мы можем положить сеть и сервер большим количеством пользователей, т.к. он постоянно будет всем слать одно и то же по запросам.
вообще использование DBGrid и других DB-компонентов при непрерывном обновлении мне кажется не очень удачным
Непрерывное не требуется, раз в 15 минут впролне хватит

Добавлено через 26 секунд
Пользователей будет макс человек 20-30
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
14.10.2016, 09:13
тогда вообще нет проблем. на 20 юзеров можно раз в 30 сек обновляться без тормозов

Добавлено через 2 минуты
но техника присоединения к каждой записи времени ее обновления вовсе неплоха
и можно скачивать только обновленные записи
только тогда точно DBGrid не подойдет
0
0 / 0 / 1
Регистрация: 02.03.2016
Сообщений: 41
14.10.2016, 09:18  [ТС]
Цитата Сообщение от krapotkin Посмотреть сообщение
тогда вообще нет проблем. на 20 юзеров можно раз в 30 сек обновляться без тормозов
Добавлено через 2 минуты
но техника присоединения к каждой записи времени ее обновления вовсе неплоха
и можно скачивать только обновленные записи
только тогда точно DBGrid не подойдет
я думаю использовать пометку об обновлении просто как индикатор т е, возьму по таймеру буду делать запрос и сравнивать были изменения или нет если да то, квери грида выключу выключу и он обновит данные в гриде, конечно решение не самое изящное
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
14.10.2016, 12:17
нормальное вполне
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.10.2016, 12:17
Помогаю со студенческими работами здесь

Где скачать обновления для AVG Internet Security для обновления в оффлайн режиме?
Сабж.

Асинхронный POST запрос по таймеру
Доброго времени суток.

Запись рандомных значений в NumericUpDown по таймеру
Здравствуйте, подскажите пожалуйста, у меня такая проблема: у меня есть несколько numericUpDown, мне нужно чтобы у меня записывались в них...

Запрос для неизвестного числа значений
Доброго времени суток Есть таблица в которую записываются адреса и значения времени для каждого адреса соответственно Необходимо...

Запрос для вывода значений в алфавитном порядке
Подскажите плиз , есть поле varchar в mysql по названием name там хранятся названия заведений , надо написать запрос который выводит...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru