Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.02.2016, 22:05
aqula aqula вне форума
Новичок
 
Регистрация: 19.10.2012
Сообщения: 95
Репутация: 10
Радость Обновление датасета по условию

Привет коллеги.
Тут заказчик хочет к моему телефонному справочнику, прикрутить типа аську или скайпа чата.
Написал уже интрефейс аля вотсап, думаю сделать на базе того же SQL Server.
Вот только думаю как оптимальнее сделать обновление адошек при общении в чате. На сервере появилось сообщение - клиент опрашивает - получает сообщение.

Есть такая идея триггером обновлять буленовское поле в табличке со статусом сообщения прочитано и не прочитано. А в 5 секундном таймере проверять это поле типа resync делать. И если есть не прочитанное - лишь тогда requery. (Или сделать по кнопке обновление??) Как вам такое? Может есть более правильные способы?
Ответить с цитированием
  #2  
Старый 04.02.2016, 02:32
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

В свое время делали подобную мониторилку для таблицы на сервере.
В итоге разных экспериментов пришли к такому варианту - периодически клиент делает запрос на сервер с получением кол-ва удовлетворяющих некоторому условию записей и их контрольной сумме (в нашем случае просто хватило суммы по паре полей). Если с последнего запроса пришли те же значения, то значит ничего нового нету и обновлять нечего.
Другой вариант, ты же не просто в гриде показываешь записи, а так, что бы красиво было?.. тогда для сообщений поставь автоматическое заполнение поля timestamp на сервере и просто получай только новые записи (время записи больше, чем время последней записи у тебя в клиенте). Тогда если ничего нового нет, то тебе вернется пустой датасет, что не хуже, чем сначала запрашивать некоторую контрольную информацию, а потом сами записи.
Ответить с цитированием
  #3  
Старый 04.02.2016, 07:49
aqula aqula вне форума
Новичок
 
Регистрация: 19.10.2012
Сообщения: 95
Репутация: 10
По умолчанию

А мне второй способ понравился.
Правильно ли я понял есть один общий датасет (например с 200 последних сообщений)
и
еще один для опроса новых сообщений. Вот пришло новое сообщение

Только как к общему датасету со всеми сообщениями в гриде добавить новое из другого датасета (без запроса)?
Или я ничкго не понял?
Ответить с цитированием
  #4  
Старый 04.02.2016, 20:00
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Видимо - не понял.
Второй вариант - это когда ты не используешь стандартный грид для отображения (есть еще вариант с копированием, см. ниже). Для отображения используется другой компонент, например ListBox с ручной отрисовкой (что б красиво было). В этом случае, сначала у тебя вообще нет записей, т.е. время последнего сообщения = 0. Соответсвенно, при первом запросе будут получены все записи, удовлетворяющие другим условиям. Берем эти записи и копируем их в ListBox (ну и можно старые удалить, если они не нужны больше). Теперь у тебя есть время последней записи, например "2016-02-04 11:55:11.123456". Соотвестенно, подставив это значение в зарос, ты получишь все записи, пришедшие после этой. Добавляешь их опять в ListBox.

Теперь, если хочется использовать тот же механизм, но с грЫдом вместо ListBox. Для этого надо просто воспользоваться любым DataSet'ом, который умеет хранить данные в памяти. Во многих библиотеках есть компоненты типа TMemTable. Так же можно воспользоваться компонентом TClientDataSet, с ним чуть геморройнее, но тоже будет работать. Принцип тот же. Рабочим датасетом получаем данные по тому же принципу и копируем их в этот датасет.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 12:57.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025