Две таблицы в одном Browse

Программирование на Атлантисе (VIP, FCOM, ARD), FastReport

Модераторы: m0p3e, edward_K, Модераторы

Ответить
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Две таблицы в одном Browse

Сообщение gloomy »

Помогите пожалуйста решить задачу....
Необходимо в одном Browse одновременно отобразить записи из двух несвязанных различных таблиц
для примера таблицы KATMC и KATUSL.
В Browse отобразить поля KATMC.NAME и KATUSL.NAME. Получается вывести только одну из таблиц или декартово произведение таблиц (заменить Table KATMC на ViewTable).


Interface Test2Table 'Test2Table' EscClose, Cyan;
Show At(,,90,20);

Create View
As Select
*
From
KATMC
,KATUSL
;

Panel pList;
Table KATMC;
Browse brTbl;
Fields
KATMC.NAME 'NAME' : [90], Protect;
End;
End;
End.
edward_K
Заслуженный деятель интернет-сообщества
Сообщения: 5188
Зарегистрирован: 29 мар 2005, 17:49
Откуда: SPB galaxy spb

Re: Две таблицы в одном Browse

Сообщение edward_K »

есть 2 пути
1. в select объявить поле
.... ,if(spsopr.prmc=1,katm.name,katusl.name) (fieldname=namespec)
допустимо использование функций, их надо перед select объявить с ключем forward
2. выражение выше использовать прямо в броусе или скрине. Минус в том что неизвестно, что возратит curfield.
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

У меня нет SPSOPR, и он мне не нужен...
Есть две независимые таблицы и они не связаны никак. И необходимо, что бы записи отображались одновременно в одном Browse сразу из обеих таблиц... Это как иметь два Browse с каждой из таблиц и слепить их вместе
Алексей
Местный житель
Сообщения: 2896
Зарегистрирован: 24 июн 2005, 12:12
Откуда: Иркутская область

Re: Две таблицы в одном Browse

Сообщение Алексей »

а какой смысл? :-?
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

Я для наглядности и упрощения задачи привел таблицы KATMC и KATUSL. Если удастся отобразить их, то более сложная и осмысленная задача тоже будет решена.
edward_K
Заслуженный деятель интернет-сообщества
Сообщения: 5188
Зарегистрирован: 29 мар 2005, 17:49
Откуда: SPB galaxy spb

Re: Две таблицы в одном Browse

Сообщение edward_K »

ну тогда вариант один - временная таблица, а поля из дочек вывести как я написал.
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

Временная таблица связи/объединения имеет один минус.
Если добавит/удалит запись в т. KATMC или KATUSL другой пользователь на другом ПК, то в таблице связи не будет видна эта запись (или надо постоянно сканировать таблицы КАТМC и KATUSL на предмет добавления/ удаления).
Задача и состоит, как обойтись без временной таблицы связи/объединения встроенными средствами или умными запросами.
LaaLaa

Re: Две таблицы в одном Browse

Сообщение LaaLaa »

Ищите в документации по Атлантису ключевое слово EventNavigation и описание событий cmDoGetPrev, cmDoGetNext, cmDoGetFirst, cmDoGetLast. Можно попробовать сделать программный обход по записям. Сначала по одной таблице. Когда она кончится перейти на другую.
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

Действительно, представляется, что код интерфейса должен выглядеть примерно так (см. ниже).
Но ни как не могу правильно запрограммировать события. Может быть, кто-то сталкивался с данными событиями и быстрее найдет решение...


Interface Test2Table 'Test2Table' EscClose, Cyan;
Show At(,,90,20);

Var
ind : integer;

Create View
As Select
*
From
KATMC
,KATUSL
;

Panel pList;
Browse brTbl;
Fields
ind 'Ind': [10], Protect;

If(TreeGetNodeTable(brTbl)=tnKATMC, KATMC.NAME, If(TreeGetNodeTable(brTbl)=tnKATUSL, KATUSL.NAME, ''))
'NAME': [20], Protect;

If(TreeGetNodeTable(brTbl)=tnKATMC, 'МЦ', If(TreeGetNodeTable(brTbl)=tnKATUSL, 'Услуга', ''))
'Услуга/МЦ': [10], Protect;
End;
End;

TableEvent Table KATMC, EventNavigation
cmDoGetFirst:
{
ind :=0;
TreeSetNodeTable(brTbl, tnKATUSL);
RescanPanel(tnKATMC);
RescanPanel(tnKATUSL);
}
cmDoGetLast:
{
ind :=0;
}
cmDoGetPrev:
{
ind:=ind-10;
}
cmDoGetNext:
{
ind :=ind+10;
}
End;

TableEvent Table KATUSL, EventNavigation
cmDoGetFirst:
{
ind := 1000;
}
cmDoGetLast:
{
ind := 1000;
TreeSetNodeTable(brTbl, tnKATMC);
RescanPanel(tnKATMC);
RescanPanel(tnKATUSL);
}
cmDoGetPrev:
{
ind :=ind-5;
}
cmDoGetNext:
{
ind :=ind+5;
}
End;

HandleEvent
cmInit:
{
ind:=500;
}
End;
End.
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

Застопорился значительный (для меня) проект из-за невозможности решить данную задачу.
Готов заплатить вознаграждение (из личных сбережений) от 300-500 WMR, первому программисту, представившему изящное решение (без таблицы связи/объединения) задачи.
Последний раз редактировалось gloomy 25 ноя 2010, 22:11, всего редактировалось 2 раза.
m0p3e
Местный житель
Сообщения: 1386
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Москва

Re: Две таблицы в одном Browse

Сообщение m0p3e »

Без временной все равно не получится, IMHO.
Другое дело, что строить ее и обновлять можно по разному.
Если СУБД Сиквел или Оракл, то прямо просится заполнение через прямой SQL + UNION :) Ну и обновление через тот же DSQL по cmIdle.
LaaLaa

Re: Две таблицы в одном Browse

Сообщение LaaLaa »

Набросал пример EventNavigation для вашего случая. Правда не совсем неправильно работают клавиши PageUp PageDown. Где то есть ошибка - не додумал.

Код: Выделить всё

Interface Test2Table blue;

Var
  WhatTable : integer;  // 0 - KatMc, 1 - KatUsl
  IsStart   : boolean;

Create View As Select * From KATMC, KATUSL;

Browse brTwoTables NotableNavigation;
Fields
  if(WhatTable = 0, 'МЦ', 'Услуга')          'Table': [10], Protect;
  if(WhatTable = 0, KatMC.NRec, KatUsl.Nrec) 'Nrec': [10], Protect;
  if(WhatTable = 0, KatMC.Name, KatUsl.Name) 'Name': [60], Protect;
End;

function GoNext : boolean;
{
  result := false;

  if( IsStart )
  {
    IsStart := false;

    if( WhatTable = 1 )
      exit;

    if( getfirst katmc = tsok )
    {
      result := true;
      exit;
    }
    else
    {
      WhatTable := 1;
      if( getfirst katusl = tsok )
      {
        result := true;
        exit;
      }
    }
  }
  else
  {
    if(WhatTable = 0)
    {
      if( getnext katmc = tsok )
      {
        result := true;
        exit;
      }
      else
      {
        WhatTable := 1;
        if( getfirst katusl = tsok )
        {
          result := true;
          exit;
        }
      }
    }

    if(WhatTable = 1)
    {
      if( getnext katusl = tsok )
      {
        result := true;
        exit;
      }
    }
  }
}

function GoPrev : boolean;
{
  result := false;

  if( IsStart )
  {
    IsStart := false;

    if( WhatTable = 0 )
      exit;

    if( getlast katusl = tsok )
    {
      result := true;
      exit;
    }
    else
    {
      WhatTable := 0;
      if( getlast katmc = tsok )
      {
        result := true;
        exit;
      }
    }
  }
  else
  {
    if(WhatTable = 1)
    {
      if( getprev katusl = tsok )
      {
        result := true;
        exit;
      }
      else
      {
        WhatTable := 0;
        if( getlast katmc = tsok )
        {
          result := true;
          exit;
        }
      }
    }

    if(WhatTable = 0)
    {
      if( getprev katmc = tsok )
      {
        result := true;
        exit;
      }
    }
  }
}

handleevent
  cmInit:
  {
    WhatTable := 0;
    IsStart := true;
  }

  cmDoGetFirst:
  {
    WhatTable := 0;
    IsStart := true;

    //if( not GoNext )
    //  abort;
  }

  cmDoGetLast:
  {
    WhatTable := 1;
    IsStart := true;

    //if( not GoPrev )
    //  abort;
  }

  cmDoGetNext:
  {
    if( not GoNext )
      abort;
  }

  cmDoGetPrev:
  {
    if( not GoPrev )
      abort;
  }
End;

End.
gloomy
Посетитель
Сообщения: 39
Зарегистрирован: 29 мар 2005, 17:49
Откуда: Архангельская область ООО "Фалькон плюс"
Контактная информация:

Re: Две таблицы в одном Browse

Сообщение gloomy »

Да, значительный прогресс!
Уверен, истина где-то рядом!
Ответить