|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
Qreport типа master-detail (table+query)31.03.2012, 17:31. Показов 2488. Ответов 6
Метки нет (Все метки)
Собственно, лабораторные делаются по учебной базе "Борей", которая идет с аксессом.
Нужен отчет типа: Товар Марка -Код заказа Название Количество Цена С master все просто - настроить на табличку "Товары" и дело в шляпе. Проблема возникает после создания запроса - выводить у меня все выводит, но как сделать так, чтобы Таблица и Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса. Для наглядности добавил часть, которую отвечает за отчет в отдельный проект (прикреплен), хоть и кривовато. Буду благодарен за подсказки. temp.rar
0
|
|
| 31.03.2012, 17:31 | |
|
Ответы с готовыми решениями:
6
Master-Detail FireBird в С++ InterBase, BDE, Master-Detail Связка двух SQL запросов Master Detail |
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 31.03.2012, 22:07 | |
|
Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса.
Очевидно я не совсем понял ваш вопрос, "связаться по полю КодТовара". Если вам нужно вывести конкретные значения например, то почему бы вам не использовать проверки типа where(" ") или установить связь при помощи компонентов в DataSourse и от туда делать связь, а потом делать запрос ?
0
|
|
|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
| 31.03.2012, 22:34 [ТС] | |
|
Nikolay88_X,
Мне нужно, чтобы выводился весь список товаров и по каждому из них список заказов с указанием имен клиентов. Это можно сделать и в 1 запрос, но мне нужен отчет именно master-detail Попробую привести пример: КодТовара1 Марка1 -КодТовара1 КодЗаказа1 Название1 Цена1 -КодТовара1 КодЗаказа2 Название2 Цена2 -КодТовара1 КодЗаказа3 Название3 Цена3 КодТовара2 Марка2 -КодТовара2 КодЗаказа4 Название4 Цена4 -КодТовара2 КодЗаказа5 Название5 Цена5 КодТовара3 Марка3 -КодТовара3 КодЗаказа6 Название6 Цена6 -КодТовара3 КодЗаказа7 Название7 Цена7 (Естественно, на отчете КодТовара в detail запросе не отображается, это просто так, для примера) Так вот, в отчете в качестве master выступает таблица "Товары", а в качестве detail выступает запрос, в котором ВСЕ значения этого запроса. Добавлено через 1 минуту P.S. У меня же получается такое: КодТовара1 Марка1 -КодТовара1 КодЗаказа1 Название1 Цена1 -КодТовара1 КодЗаказа2 Название2 Цена2 -КодТовара1 КодЗаказа3 Название3 Цена3 -КодТовара2 КодЗаказа4 Название4 Цена4 -КодТовара2 КодЗаказа5 Название5 Цена5 -КодТовара3 КодЗаказа6 Название6 Цена6 -КодТовара3 КодЗаказа7 Название7 Цена7 КодТовара2 Марка2 -КодТовара1 КодЗаказа1 Название1 Цена1 -КодТовара1 КодЗаказа2 Название2 Цена2 -КодТовара1 КодЗаказа3 Название3 Цена3 -КодТовара2 КодЗаказа4 Название4 Цена4 -КодТовара2 КодЗаказа5 Название5 Цена5 -КодТовара3 КодЗаказа6 Название6 Цена6 -КодТовара3 КодЗаказа7 Название7 Цена7 КодТовара3 Марка3 -КодТовара1 КодЗаказа1 Название1 Цена1 -КодТовара1 КодЗаказа2 Название2 Цена2 -КодТовара1 КодЗаказа3 Название3 Цена3 -КодТовара2 КодЗаказа4 Название4 Цена4 -КодТовара2 КодЗаказа5 Название5 Цена5 -КодТовара3 КодЗаказа6 Название6 Цена6 -КодТовара3 КодЗаказа7 Название7 Цена7
0
|
|
|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
| 31.03.2012, 22:36 [ТС] | |
|
Ах да, на случай, если нету Борея у кого. Ложить в корень С:\
DSN внутри, но это не важно.
0
|
|
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 01.04.2012, 11:53 | |
|
Ваш запрос состоял из:
SELECT Заказано.КодТовара, Заказано.КодЗаказа, Заказано.Цена, Заказано.Количество, Клиенты.Название FROM Клиенты INNER JOIN (Заказы INNER JOIN Заказано ON Заказы.КодЗаказа = Заказано.КодЗаказа) ON Клиенты.КодКлиента = Заказы.КодКлиента; Пример: SELECT Заказы.КодКлиента, Товары.Марка, Sum(CCur(Заказано!Цена*Заказано!Количест во*(1-Заказано!Скидка))) AS Выручка, Sum(CCur((Заказано!Цена*Заказано!Количес тво*(1-Заказано!Скидка))-(Товары!Цена-Заказано!Количество))) AS Маржа, Заказы.ДатаРазмещения FROM (Типы INNER JOIN (Поставщики INNER JOIN Товары ON Поставщики.КодПоставщика=Товары.КодПоста вщика) ON Типы.КодТипа=Товары.КодТипа) INNER JOIN (Заказы INNER JOIN Заказано ON Заказы.КодЗаказа=Заказано.КодЗаказа) ON Товары.КодТовара=Заказано.КодТовара WHERE Типы.Категория="Напитки" And Заказы.ДатаРазмещения Between #1/1/1996# And #1/1/2000# GROUP BY Заказы.СтранаПолучателя, Заказы.КодКлиента, Товары.Марка, Заказы.ДатаРазмещения Having Товары.Марка & "|" & Заказы.КодКлиента not in (SELECT Товары.Марка & "|" & Клиенты.КодКлиента FROM Клиенты INNER JOIN (Заказы INNER JOIN ((Типы INNER JOIN (Поставщики INNER JOIN Товары ON Поставщики.КодПоставщика = Товары.КодПоставщика) ON Типы.КодТипа = Товары.КодТипа) INNER JOIN Заказано ON Товары.КодТовара = Заказано.КодТовара) ON Заказы.КодЗаказа = Заказано.КодЗаказа) ON Клиенты.КодКлиента = Заказы.КодКлиента WHERE Типы.Категория="Напитки" AND Заказы.ДатаРазмещения Between #1/1/1998# And #3/31/1998# GROUP BY Товары.Марка & "|" & Клиенты.КодКлиента) Отсюда следует что вы не выполняли проверки на наличие совместимости, и поэтому у вас Не по порядку выводит. И получается -КодТовара1 КодЗаказа1 Название1 Цена1 -КодТовара1 КодЗаказа2 Название2 Цена2 -КодТовара1 КодЗаказа3 Название3 Цена3 -КодТовара2 КодЗаказа4 Название4 Цена4 -КодТовара2 КодЗаказа5 Название5 Цена5 -КодТовара3 КодЗаказа6 Название6 Цена6 -КодТовара3 КодЗаказа7 Название7 Цена7
0
|
|
|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
| 01.04.2012, 12:34 [ТС] | |
|
Nikolay88_X, похоже, Вы меня все-таки не поняли =(
Не в самом запросе дело, и даже то, что он не по порядку ничего не меняет. Мне нужно, чтобы в самом отчете в качестве Detail заголовка были товары, а в качестве SubDetail все заказы по данному товару. Попробую привести пример в качестве исходника для двух таблиц "Клиенты - заказы". Вот, что я получил: Для 2й таблицы есть свойство Master и выбор поля, по которому она связывается с родительской. Для Query такого поля я не нашел, а выполнять много раз 1 запрос с разными параметрами, чтобы получить данные для отчета конечно можно, но можно ли их потом будет в 1 отчет склеить?
0
|
|
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 01.04.2012, 15:41 | |
|
чтобы связать запрос по полю из таблицы для Table1 нужно сделать примерно такое
Для Query будет так select *from Товары where(Товары=:заказы); заказы - это параметр из другой таблице затем если Query у вас вспомогательная таблица то настройте ее Datasourse на Datasourse1 и тогда вы их свяжите....
0
|
|
| 01.04.2012, 15:41 | |
|
Помогаю со студенческими работами здесь
7
Организация заголовков в qreport detail
Master-detail JqGrid master detail Master Detail Flow Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
|
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo
Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло.
Но на выплатах по больничным это. . .
|
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
|
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y
Z4Tv2zpXVVo
https:/ / github. com/ shumilovas/ med2. git
|
|
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа.
В качестве фильтра для отбора справочника служит группа номенклатуры.
Отбор по наименованию группы. . .
|
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
|
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс.
Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
|
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа.
В качестве фильтра для отбора служит значение перечислений.
/ / Событие "НачалоВыбора" реквизита на форме. . .
|