|
0 / 0 / 0
Регистрация: 06.08.2016
Сообщений: 4
|
|
Видимость изменений данных разными пользователями06.08.2016, 18:00. Показов 936. Ответов 11
Метки нет (Все метки)
Ситуация следующая. Два пользователя работают с одной базой. В базе есть таблица из 4 заданий. Оба пользователя запустили свое приложение Delphi и видят эти 4 задания. Теперь первый пользователь добавил еще одно задание. Как сделать так, чтобы второй пользователь сразу увидел эти изменения у себя?
Мой вариант решения: Чтобы второму пользователю увидеть сделанные изменения, ему нужно переоткрыть таблицу (т.е. Close-Open). Значит я запускаю таймер, который через интервал времени переоткрывает таблицу для нахождения изменений. Может быть есть лучшее решение?
0
|
|
| 06.08.2016, 18:00 | |
|
Ответы с готовыми решениями:
11
Редактирование dbgrid разными пользователями Как установить две версии ZeosDBO, но под разными пользователями в D7? Передача данных между БД с разными пользователями |
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 06.08.2016, 19:36 | |
|
Можно и по таймеру.
А есть СУБД, в которых можно от сервера посылать событие в клиентскую программу. При модификации данных все клиенты получают это событие и переоткрывают свой набор данных. К примеру, такая возможность есть в Firebird. Только в любом случае не забыть перед переоткрытием отключать прорисовку отображения данных, а после переоткытия установить указатель на ту строку, на которой он был установлен пользователем.
0
|
|
|
Хитрая блондиночка $)
1472 / 988 / 399
Регистрация: 21.12.2015
Сообщений: 3,785
|
||
| 06.08.2016, 19:43 | ||
|
Пользователь регистрируется в таблице базы как активный, и изменяющий клиент всем активным пользователям рассылает сообщения о необходимости обновиться.
0
|
||
|
пофигист широкого профиля
4769 / 3204 / 862
Регистрация: 15.07.2013
Сообщений: 18,609
|
||
| 07.08.2016, 00:47 | ||
|
Он не зависит от СУБД и способен обеспечить достаточно срочное оповещение клиентов об изменении данных. Но тут требуется дополнительная работа.
0
|
||
|
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
|
||
| 07.08.2016, 01:59 | ||
|
0
|
||
|
пофигист широкого профиля
4769 / 3204 / 862
Регистрация: 15.07.2013
Сообщений: 18,609
|
|
| 07.08.2016, 02:20 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 06.08.2016
Сообщений: 4
|
|
| 11.08.2016, 14:11 [ТС] | |
|
Спасибо всем за ответы. У меня сейчас работа Delphi+ADO+Postgresql. Все работает нормально. На данный момент свою задачу решаю через таймер. Посылаю минимальный запрос - получаю последние данные. На других форумах - это самое частое решение.
При работе с Postgresql есть решение применить оповещения по командам NOTIFY/Listen. Но как получить это оповещение в программе? Например: В Delphi-программе я делаю запрос "Listen MyTask;" //теперь будем слушать оповещение MyTask от сервера На сервере делаю команду "NOTIFY MyTask;" // возникло оповещение для всех слушающих Где я в delphi-программе должен ловить это оповещение? Куда оно приходит? Где можно посмотреть код отлова этого оповещения?
0
|
|
|
|
|
| 11.08.2016, 14:39 | |
|
ну, как сказать. в двух словах - нигде
зачем вы связались с ADO ? http://docwiki.embarcadero.com... s_(FireDAC)
0
|
|
|
0 / 0 / 0
Регистрация: 06.08.2016
Сообщений: 4
|
|
| 11.08.2016, 14:47 [ТС] | |
|
Мне нужен бесплатный компонент, чтобы не было вопросов по лицензиям или покупке чего-либо еще. Ваш вариант FireDac предполагает покупку лицензии? У меня есть еще вариант перейти на zeoslib - тоже бесплатно. Как там решается поставленный вопрос - тоже пока не знаю. Возможно, есть спец команда.
0
|
|
|
0 / 0 / 0
Регистрация: 06.08.2016
Сообщений: 4
|
|
| 12.08.2016, 08:09 [ТС] | |
|
Спасибо за комментарии, мы отошли от темы.
0
|
|
| 12.08.2016, 08:09 | |
|
Помогаю со студенческими работами здесь
12
Пополнение таблицы разными пользователями Доступ между Windows 7 в рабочей группе с разными пользователями Delphi: Запрет запуска второй копии разными пользователями!
Программа для работы в реальном времени с одним и тем же файлом (или файлами) разными пользователями Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
|
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|