Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Потрепаться";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Вниз

Соединяющие запросы в .Net и Delphi   Найти похожие ветки 

 
by ©   (2004-12-06 15:25) [0]

Есть как минимум два варианта получения данных в клиентское приложение. Пример.
У нас есть таблица оплат клиентов Pmnt и таблица самих клиентов Person
Pmnt
PmntID  PersonID  SumPmnt  PmntDt
100     10        20       10.10.04
101     10        30       11.10.04
102     11        25       11.10.04
..................
1000    10        100      30.10.04

Person
PersonID  Name
10        Иванов
11        Петров
...

Первый способ получения данных на клиента

Мы можем составить запрос вида
Select C.Name, P.PmntDt, P.SumPmnt
From Pmnt P, Person C
Where P.PersonID=C.PersonID

и получить на выходе на клиенте таблицу вида
C.Name       P.PmntDt   P.SumPmnt
Иванов       10.10.04   20
Иванов       11.10.04   30
Петров       11.10.04   25
...

==========

Второй способ.
Мы получаем отдельно на клиента выборку из Pmnt и соответствующие им Person и через LookupField (в Delphi) или DataSet/DataTable (.Net) соединяем.

При первом способе у нас в минусах избыточный трафик, а при втором - проблемы с фильтрицией и сортировкой.

Какие методы используете вы? и причины этого


 
Petr V. Abramov ©   (2004-12-06 16:10) [1]

> При первом способе у нас в минусах избыточный трафик
 Избыточный трафик будет, если выбрать все оплаты всех клиентов. Это кому-нить нужно? Это реально просмотреть и не утонуть?


 
Petr V. Abramov ©   (2004-12-06 16:10) [2]

> При первом способе у нас в минусах избыточный трафик
 Избыточный трафик будет, если выбрать все оплаты всех клиентов. Это кому-нить нужно? Это реально просмотреть и не утонуть?


 
by ©   (2004-12-06 16:15) [3]

Petr V. Abramov ©   (06.12.04 16:10) [2]
Ну а если по каждому клиенту за период отбора по 100 записей и нужно не только Наименование клиента показываеть, но и код и еще какую-то инфу. Тогда же избыточный трафик будет?


 
by ©   (2004-12-06 16:26) [4]

Этот вопрос я поднял потому что в книге Девида Сеппа ADO.NET подход раздельных запросов описан как более правильный. Вот и интересно мнение.


 
Sergey13 ©   (2004-12-06 16:34) [5]

Второй способ использую иногда, обычно когда лукапный (справочный) НД не большой. Иначе, для показа запроса по 1 (10,20) человеку тащится на клиента весь справочник людей, а там может и 1000 и 2000 и 1000000 записей. Хотя иногда бывает выгоднее закачать весь справочник. В общем, по обстоятельствам.


 
Petr V. Abramov ©   (2004-12-06 16:35) [6]

by ©   (06.12.04 16:15) [3]
> Ну а если по каждому клиенту за период отбора по 100 записей и
> нужно не только Наименование клиента показываеть, но и код и
> еще какую-то инфу. Тогда же избыточный трафик будет?
 При небольшой выборке ( а только небольшие имеют право на жизнь), боюсь, этот избыточный трафик будет сопоставим с трафиком на отправку нового запроса. И несопоставим с геморроем при втором варианте

> подход раздельных запросов описан как более правильный. Вот и
> интересно мнение.
 мнение - заговор производителей памяти. Которая будет тратиться на join на клиенте (уверен, не лучшим образом реализованный).


 
by ©   (2004-12-06 16:39) [7]

Petr V. Abramov ©   (06.12.04 16:35) [6]
Но на клиенте join будет наверное только в момент отображения запис на экране.

Хотя тот же Сеппа говорит что раздельные запросы очень удобны для редактирования данных, в самом датасете. Я так не делаю, список для отображения, а для редактирования - выбирается отдельная запись. Может если не редактировать в списке/гриде, тогда и преимущества раздельного подхода теряются.


 
Sergey13 ©   (2004-12-06 16:41) [8]

2[7] by ©   (06.12.04 16:39)
>Я так не делаю, список для отображения, а для редактирования - выбирается отдельная запись.
А потом обновляешь запрос для отображения. Вот и трафик полез. 8-)


 
Petr V. Abramov ©   (2004-12-06 19:56) [9]

> а для редактирования - выбирается отдельная запись.
> А потом обновляешь запрос для отображения. Вот и трафик полез. 8-)

 А зачем обновлять - CachedUpdates и нормально. При выборке отдельной записи ее как раз и for update святое дело выбрать



Страницы: 1 вся ветка

Форум: "Потрепаться";
Текущий архив: 2004.12.26;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.47 MB
Время: 0.042 c
1-1101809255
JohnS
2004-11-30 13:07
2004.12.26
Cron формат


1-1102417746
COOLer
2004-12-07 14:09
2004.12.26
подсветка букв в RichEdit


1-1102800010
Geo
2004-12-12 00:20
2004.12.26
проблема с RichEdit


3-1101317039
Sergy Ivanec
2004-11-24 20:23
2004.12.26
Вопрос по Fastreport


4-1100327202
ддд
2004-11-13 09:26
2004.12.26
service & tray icon





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский