Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.12.26;
Скачать: CL | DM;

Вниз

Соединяющие запросы в .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;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.041 c
3-1101213294
ВицеЧайник
2004-11-23 15:34
2004.12.26
SQL запрос


14-1102448705
Hypercube
2004-12-07 22:45
2004.12.26
Печедача "Теория невероятностей"


14-1102253374
NailMan
2004-12-05 16:29
2004.12.26
Хорошие ресторанчики для проведения мероприятий


1-1102685710
mefisto
2004-12-10 16:35
2004.12.26
Как захватить текущий URL из окна Internet Explorer.


1-1102591771
Lera
2004-12-09 14:29
2004.12.26
OnKeyUp





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский