![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
||||
|
||||
![]() Код:
в общем есть такой код отправки уведомления абону от том что у него истекает серт через столько-то дней по состоянию на дату отправки. Недостаток: нужно сделать запрос на выборку таких сертификатов. вывести это все в ДБГрид, и поочередно открывать каждую такую строку и отправлять уведомление кнопкой отправить. Подскажите пожалуйста как можно научить делать программу эту функцию автоматически. Что бы два раза в день, например, она прогоняла запрос на поиск сертификатов срок которых истекает менее чем через 30 дней и отправляла подобное сообщение автоматически, без участия пользователя, том случает если статус сообщения на момент отправки "Готово к отправке".В идеале, делать она это должна в фоновом режиме. Что бы сотруднику осталось только заходить время от времени и проверять все ли нормально отправляется. |
#2
|
||||
|
||||
![]() Для начала, данные надо брать не из DBGrida а непосредственно из источника. Далее, данные источника надо формировать с учетом ваших требований. И наконец, что-бы это все работало автоматом, самый простой способ бросить на форму компонент TTimer и выставить интервал скажем 10000 = 10 минут. В событие таймера переносите ваш код и делаете сначала выборку данных по определенному критерию, а уже потом по полученному результату выполняете свой код отправки сообщений.
Жизнь такова какова она есть и больше никакова. Помогаю за спасибо. |
#3
|
||||
|
||||
![]() Ага...спасибо, что подтвердил мои догадки.
Я представлял примерно так: запрос на выборку по условию, где дата_окончания- NOW<=30 и статус "Готово в отправке"; далее код отправки сообщения, далее процедуру обновления записи в таблице с этим ИД (меняем статус с "готово к отправке" на "отправлено"). далее тянем следующую запись. Вопрос теперь в следующем: 1. как это все замутить в фоне? 2. будет ли SQL ,блокировать транзакции на добавление новой записи в тот момент, когда будет выполняться описанный выше код? 3. и еще: как заставить делфи брать время с какого-нибудь более надежного ресурса, не с компа. А то вдруг кривые руки поменяют сис.время на компе и прога начнет рассылать сообщения "из будущего" ![]() |
#4
|
||||
|
||||
![]() Цитата:
![]() Цитата:
Цитата:
Жизнь такова какова она есть и больше никакова. Помогаю за спасибо. |
#5
|
||||
|
||||
![]() Я думаю написать отдельный модуль, который будет запускаться с виндой в виде процесса и висеть в трее. Делать будет следующее: время от времени обновлять записи в БД, вычисляя сколько дней осталось до истечения серта, отправлять уведомления, и производить апдейт статуса с "готово к отправке" на "отправлено". делать это будет по таймауту в полностью автоматическом режиме. по сути дела это будет второе приложение, работающее с этой же базой. Думаю должно прокатить.
|
#6
|
|||
|
|||
![]() Лучше сервис напиши.
|
#7
|
|||
|
|||
![]() Цитата:
OnTimer выполняется в основном потоке. |
#8
|
||||
|
||||
![]() Цитата:
![]() |
#9
|
||||
|
||||
![]() С работой приложения в фоне разобрался. Теперь проблема в другом:
вытягивать запись из базы, проверять на условие. Если условие выполняется, отправлять сообщение на мэйл, взятый из этой записи с данными из этой же записи, обновлять запись. Только после этого переходить к другой и так далее. Если условие не выполняется, то переходить к другой записи, пока не дойдем до нужной или до конца таблицы. Например ФИО Возраст Статус сообщения. Если возраст=30 и статус сообщения "готово к отправке", то отправляем " <ФИО>, вам сегодня <возраст>", далее обновляем запись статус сообщения:=<отправлено> иначе тянем другую запись. зы: надеюсь,понятно описал проблему. |
#10
|
||||
|
||||
![]() Проблема решена. Всем спасибо.
Кому интересно, как решил, могу скинуть код. |