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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 26.10.2017, 20:56
Xvir43 Xvir43 вне форума
Прохожий
 
Регистрация: 30.11.2016
Сообщения: 5
Версия Delphi: xe10
Репутация: 10
По умолчанию Помогите с логикой работы программы

Привет всем , помогите разобраться.
Есть база данных MySQL в ней таблица с заявками на покупку чего либо.
Есть программа которая должна читать эти данные и выводить пользователю, дак вот вопрос , как правильно это сделать?
Мои догадки что нужно хранить в каком то формате эту базу и сравнивать через определенное время ид заявок и если в удаленной базе больше чем в локальной то нужно догрузить , если так то каком формате хранить данные локально если будет предположим 1000 заявок потом ещё больше. Может уже сталкивались с таким
Ответить с цитированием
  #2  
Старый 26.10.2017, 21:17
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,004
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, можно поставить MySQL локально.
Можно использовть Embedeed Interbase/Firebird. Или поставить полные версии локально.
Теоретически, можно просто хранить в xml и пользовать через TClientDataSet, но предполагаемые объемы великоваты.

А что мешает работать напрямую с главной БД? Тебе нужен этот геморрой с синхронизацией?

ЗЫ. У нас была подобная гетерогенная система, где был большой сервер Oracle (кстати, главный офис работал с ним напрямую) и куча удаленных точек с установленной MSDE (тот же MS SQL Server, но упрощенный и "мало"-пользовательский). Но там изначально требование было для работы off-line или на очень плохих и/или медленных каналах. Там, где канал позволял, работали с большим сервером.
Ответить с цитированием
  #3  
Старый 27.10.2017, 07:04
Xvir43 Xvir43 вне форума
Прохожий
 
Регистрация: 30.11.2016
Сообщения: 5
Версия Delphi: xe10
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Ну, можно поставить MySQL локально.
Можно использовть Embedeed Interbase/Firebird. Или поставить полные версии локально.
Теоретически, можно просто хранить в xml и пользовать через TClientDataSet, но предполагаемые объемы великоваты.

А что мешает работать напрямую с главной БД? Тебе нужен этот геморрой с синхронизацией?

ЗЫ. У нас была подобная гетерогенная система, где был большой сервер Oracle (кстати, главный офис работал с ним напрямую) и куча удаленных точек с установленной MSDE (тот же MS SQL Server, но упрощенный и "мало"-пользовательский). Но там изначально требование было для работы off-line или на очень плохих и/или медленных каналах. Там, где канал позволял, работали с большим сервером.


Могу и напрямую , я просто подумал что каждый раз при открытии программы нужно будет подгружать эти заявки и выводить пользователю и по мне это долго наверное, хотя если подгружать только последние 10 а все остальное разбить якобы на странички и при обращение ко второй странице выводить ещё 10 предыдущих и так далее тогда это будет не так ресурсоемко. Хм.. попробую)))
Ответить с цитированием
  #4  
Старый 27.10.2017, 17:39
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,004
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, эту проблему решали вводом принудительного фильтра. Т.е. по дефолту фильт включен и показывается только ограниченное кол-во записей (в зависимости от проекта фильтры были разные). Но всегда можно его "отключить" (т.е. выбрать вариант "все" или что-то подобное). Т.е. пользователь сознательно настраивает/отключает фильтр и подтверждает, что готов ждать результатов запроса. Ну и для убыстрения в основной грид выводилась (и выбиралась из БД) не вся информация, а только относительно небольшой набор ключевых полей.
Ответить с цитированием
  #5  
Старый 27.10.2017, 20:36
Xvir43 Xvir43 вне форума
Прохожий
 
Регистрация: 30.11.2016
Сообщения: 5
Версия Delphi: xe10
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Ну, эту проблему решали вводом принудительного фильтра. Т.е. по дефолту фильт включен и показывается только ограниченное кол-во записей (в зависимости от проекта фильтры были разные). Но всегда можно его "отключить" (т.е. выбрать вариант "все" или что-то подобное). Т.е. пользователь сознательно настраивает/отключает фильтр и подтверждает, что готов ждать результатов запроса. Ну и для убыстрения в основной грид выводилась (и выбиралась из БД) не вся информация, а только относительно небольшой набор ключевых полей.
Почитав я подумал что лучше будет создавать временную таблицу и туда помещать отфильтрованные данные ( критерии выбирает пользователь из программы) и выводить их как я говорил понесколько записей. Ну и про ограничение записей я теперь тож почитаю, а ввывод идёт не в таблицу дБгрид а из ячейки по ид берутся данные и записываются в созданную форму ( лайблы восновном).

Последний раз редактировалось Xvir43, 27.10.2017 в 20:39.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter