Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 18.03.2018
Сообщений: 14

Вывод нескольких дат в одну строку

06.02.2019, 11:25. Показов 1527. Ответов 4
Метки sql, бд (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Подскажите, пожалуйста, есть условная база данных, в которой содержатся следующие таблицы:
Книги (номер книги, название книги)
Дата поступления (номер книги, дата поступления, кол-во экземпляров)
Одинаковые книги могут поступать в библиотечный фонд в разные даты
Нужно вывести для каждой книги даты поступления и количество экземпляров.
Я понимаю, как посчитать общее кол-во экземпляров отдельной книги, но как сделать так, чтобы отображалось:
название книги - несколько дат поступления - количество экземпляровне могу
Буду очень благодарна за наводку
Пока что код такой (очевидно, что он не будет выводить так, как мне надо):
SQL
1
2
3
4
5
SELECT ‘НАЗВАНИЕ КНИГИ’, ‘ДАТА ПОСТУПЛЕНИЯ В БИБЛИОТЕКУ’, ‘КОЛИЧЕСТВО ЭКЗЕМПЛЯРОВ’  
FROM ‘КНИГА’
INNER JOIN ‘ПОСТУПЛЕНИЕ КНИГИ’
ON ‘ПОСТУПЛЕНИЕ КНИГИ.НОМЕР КНИГИ = КНИГА.НОМЕР КНИГИ’
GROUP BY ‘НАЗВАНИЕ КНИГИ’, ‘ДАТА ПОСТУПЛЕНИЯ В БИБЛИОТЕКУ’, ‘КОЛИЧЕСТВО ЭКЗЕМПЛЯРОВ’;
Также прикрепляю картинку задания, вдруг, я просто неправильно его интерпретирую
Миниатюры
Вывод нескольких дат в одну строку  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.02.2019, 11:25
Ответы с готовыми решениями:

Вывод всех дат
Добрый день! Подскажите, пожалуйста, как релизовать следующую вещь. Имеется таблица заказчиков и заказов (ссылка на заказчика, дата,...

Вывод данных из нескольких таблиц в одну
Здравствуйте. Требуется построить запрос, что бы из таблиц Bloki_Pitaniya, Jestkie_Diski, Korpusa, Materinskie_Plati, Operativnaya_Pamyat,...

Вывод результатов нескольких запросов в одну таблицу.
Добрый день. Не получается написать скрипт. ПОМОГИТЕ ПОЖАЙЛУСТА Есть первый скрипт select поставщик, COUNT...

4
Эксперт MS Access
 Аватар для ltv_1953
17536 / 7288 / 1663
Регистрация: 21.06.2012
Сообщений: 13,957
06.02.2019, 12:20
А SQL то какой. В MySQL есть для этого GROUP_CONCAT(), например ... .
0
0 / 0 / 0
Регистрация: 18.03.2018
Сообщений: 14
06.02.2019, 12:49  [ТС]
Цитата Сообщение от ltv_1953 Посмотреть сообщение
А SQL то какой. В MySQL есть для этого GROUP_CONCAT(), например ... .
Если бы я знала.
Помогаю другу решать задания, но они проходили на парах лишь простые запросы, перекрестные запросы, агрегирующие функции, редактирование и добавление данных в таблицы. Я не представляю, как выполнить это задание (да и первое) только с помощью этих средств.
Нашла запрос с использование STUFF, переписала для моей ситуации
SQL
1
2
3
4
5
6
7
8
SELECT ‘НАЗВАНИЕ КНИГИ’, SUM(‘КОЛИЧЕСТВО ЭКЗЕМПЛЯРОВ’),
COALESCE( 
STUFF( 
(SELECT ',' + CAST(‘ДАТА ПОСТУПЛЕНИЯ В БИБЛИОТЕКУ’ AS VARCHAR (20)) AS [text()]
FROM ‘ПОСТУПЛЕНИЕ КНИГИ’
WHERE ‘ПОСТУПЛЕНИЕ КНИГИ.НОМЕР КНИГИ = КНИГА.НОМЕР КНИГИ’
FOR XML PATH (‘ ‘), TYPE).value(.,VARCHAR(MAX)), 1, 1, ‘ ‘), ‘ ‘)
FROM ‘КНИГА’
Но ведь на простых SELECT'ах это не сделать. Или я не права?

Добавлено через 9 минут
Видимо, и тот код неверный, неработает. Отталкивалась от этого:
SQL
1
2
3
4
5
6
7
8
9
10
11
SELECT custid,
  COALESCE(
    STUFF(
      (SELECT ',' + CAST(orderid AS VARCHAR(10)) AS [text()]
       FROM Sales.Orders AS O
       WHERE O.custid = C.custid
       ORDER BY orderid
       FOR XML PATH(''), TYPE).value('.', 'VARCHAR(MAX)'),
      1, 1, ''),
    '') AS custorders
FROM Sales.Customers AS C;
0
Эксперт MS Access
 Аватар для ltv_1953
17536 / 7288 / 1663
Регистрация: 21.06.2012
Сообщений: 13,957
06.02.2019, 13:42
Смотрите варианты http://hiprog.com/index.php?op... iew&id=334. Но лучше бы узнать - какой SQL.
0
476 / 239 / 114
Регистрация: 12.05.2016
Сообщений: 647
07.02.2019, 00:27
Исходя из того, что на парах проходили только простые запросы, мне кажется вы неверно поняли задание.

Не нужно для одной книги в строку конкатенировать все даты.
Нужна просто сводная таблица "для каждой книги - даты поступлений и количество экземпляров"


КнигаДата поступленияКол-во
Книга101-01-20192
Книга102-01-20195
Книга103-01-20191
Книга201-01-20196
Книга202-01-20198
Книга203-01-20194
Книга306-02-20199


т.е. банальный джоин с группировкой по книге и дате + SUM по количеству
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.02.2019, 00:27
Помогаю со студенческими работами здесь

Хранение в одном поле нескольких дат, и работа с ними
Здравствуйте. Допустим у меня БД библиотеки. И я хочу хранить все данные по книге, когда её брали и когда сдавали. Но я хочу сделать...

Выборка из нескольких таблиц в одну
Всем привет есть две таблицы Таблица1 : id | phone Таблица2 : id | number Как вывести колонку phone и number в одну например...

Объединение нескольких строк в одну
Добрый день. Подскажите как объединить несколько строчек в одну Пример: Есть такая таблица ИД| Тип| Дата| ...

триггер из нескольких таблиц в одну
Здравствуйте! Необходима помощь. Допустим есть три таблицы ex1, ex2, ex3 с полями ex1 (pole1) ex2(pole2) ex3(pole31 pole32), нужно написать...

Вывод данных из нескольких строк таблицы в одну строку через разделитель (пробел, запятую)
Добрый день! Есть табличка с адресами: addr ul1 ul2 dom вул. 1 Травня вул. 1 Травня 1 вул. 1...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru