Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  06:04[Войти] | [Зарегистрироваться]
Ответ на вопрос № 46079

23-10-2006 00:59
Здравствуйте, уважаемые!

Delphi 7
FastReport 3.20

  Дело такое - нужно печатать подряд 2 копии каждого экземпляра в отчете. И вот для таких целей придумал создавать запрос с объединением

SELECT qq, qq1, qq2 FROM TABEL_MY
UNION ALL
SELECT qq, qq1, qq2 FROM TABEL_MY


Всё прекрасно - в датасет есть в двух экземплярах, а фаст упорно выводит в отчёте в одном! Что делать? Нужно чтобы сохранялись копии строк в отчете.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

26-10-2006 07:15 | Сообщение от автора вопроса
Ура оно работает!
Спасибо огромное!
Очень помог.
Как всегда всё гениальное просто :)

26-10-2006 02:38
Вот с такой постановки и надо было начинать. В этом случае проще будет сделать через объединяющий запрос. Попробуй так:

SELECT ID, NETTO, TIME_IN, DATE_IN, NAME_ORG, NUM, 0 as GroupIndex
FROM VES_V
WHERE ...
union all
SELECT ID, NETTO, TIME_IN, DATE_IN, NAME_ORG, NUM, 1 as GroupIndex
FROM VES_V
WHERE ...
ORDER BY name_org, GroupIndex, date_in, time_in


А в отчет добавь еще один GroupHeader (пустой, с нулевой высотой) с группировкой по полю GroupIndex и поставь его самым первым, перед GroupHeader'ом по организации.

26-10-2006 00:35 | Сообщение от автора вопроса
Не получается что-то у меня. С возможностями скрипта знаком мало. Можно поподробнее плиз!

Вот мой запрос целиком (без объединения)


function TFReestr.Get_Querry_Without_Num: string;
var
  s: string;
  i: integer;
begin
  s := '(';

{тут мы определяем, что выделил пользователь и генерим WHERE}
  for i := 0 to dbg1.SelectedRows.Count - 1 do
  begin
    dbg1.DataSource.DataSet.GotoBookmark(Pointer(dbg1.SelectedRows.Items[i]));
    s := s + '(ORG_CODE=' + dbg1.DataSource.DataSet.FieldByName('ORG_CODE').AsString + ') OR ';
  end;

  Delete(s, Length(s) - 3, 4);

  s := s + ') AND (';
{добавляем в WHERE фильтр по датам}
  s := s + 'date_in BETWEEN ' + QuotedStr(ed1.Text) + ' AND ' + QuotedStr(ed2.Text) + ') ';

{вот и сам запрос в форме для группирующего отчета}
  Result := 'SELECT ID, NETTO, TIME_IN, DATE_IN, NAME_ORG, NUM FROM VES_V WHERE ' + s +
    'ORDER BY name_org, date_in, time_in;';
end;



Теперь как у  меня выглядит отчет:
1. сначала заголовок первой группы по полю имя организации: на группе лежит мемо с именем и кодом организации из БД
2. Заголовок второй группы по полю дата, на нем MasterData. Вверху пишется текущая дата из БД, а в MasterData идут записи из БД с времнем и весом.
3.Потом идут два подвала и на последнем отображается сумма по весу в клонках и текущая дата.

Вот. И надо чтобы этот набор 2 раза подряд вывелся.  Что делать ума не приложу.

Очень надеюсь на помощь!

24-10-2006 06:06
Это так и должно быть или это как-то можно отключить?
Какое поле задано в группировке, по тому он и группирует, две одинаковые записи всегда попадут в одну группу. Получается, что их  надо "разгруппировать". Можно попробовать такие варианты:

Добавить в запрос дополнительное поле и в отчете группировать по нему:

SELECT qq, qq1, qq2, 0 as GroupIndex FROM TABEL_MY
UNION ALL
SELECT qq, qq1, qq2, 1 as GroupIndex FROM TABEL_MY


Или другой вариант, без объединяющего запроса - в скрипте отчета написать обработчик GroupFooter2AfterPrint (для бэнда, который выводится последним) и в нем сделать "ручной" повторный вывод требуемых бэндов через Engine.ShowBand

23-10-2006 10:55 | Сообщение от автора вопроса
Точнее они есть, но так как-будто бы я дейстительно продублировал в MasterData1 строки. Он не хочет делать группирующий отчет по каждой строке - он объединяет их. Вот что мне не нужно. Это так и должно быть или это как-то можно отключить?

23-10-2006 10:43 | Сообщение от автора вопроса
Либо в запросе с объединением задать ORDER BY чтобы две одинаковые записи шли подряд.

Дык у меня так и есть. Проблемма: фаст - убирает дубли! Я же говорю в датасете всё нормарльно - я на DBGrid выводил смотрел. Там подряд идут  2 одинаковые строки, а фасту побоку :(

Надо либо на MasterData продублировать поля, тогда запроса с объединением не нужно.
Не в моём случае - у меня группирующий запрос. Я смогу получить только дубль строк в MasterData1 и всё, а у меня же целая форма. GropeHeader1, GroupHeader2, GroupeFooter1, GroupeFooter2 и т.п. Если просто продублировать эти компоненты, то отработает сначала один MasterData, а потом второй - по другому я не знаю как можно сделать.

Вопрос-то - почему дублей нет в отчете? Когда они есть в результатах запроса.

23-10-2006 08:13
мне надо, чтобы каждая строка из БД прозвучала 2 раза и сразу
Надо либо на MasterData продублировать поля, тогда запроса с объединением не нужно. Либо в запросе с объединением задать ORDER BY чтобы две одинаковые записи шли подряд.

23-10-2006 06:52 | Сообщение от автора вопроса
не мне не это надо. мне надо, чтобы каждая строка из БД прозвучала 2 раза и сразу. У меня результат - отчет с подгруппами. Группировка по организации. Формируется отчет по каждой организации - а их там море. Всё печатаестя на рулоне. Вот мне и надо, чтобы подряд шло 2 копии одной записи по критерию группировки. А не сначало вся БД, а потом еще раз.

Мне вот и нужно узнать - какого фаст не хочет отображать дубликаты - если мне надо, чтобы они были! Не может же быть, чтобы такой возможности не было.

23-10-2006 01:43
Зачем запрос с объединением? Если 2 копии надо выводить только на печать - поставь PrintOptions.Copies:=2, если 2 копии надо выводить еще и на экран, то так:

frxReport1.PrepareReport(true);
frxReport1.PrepareReport(false);
frxReport1.ShowPreparedReport;


Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Зимой — белый, летом — серый. Кто?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования