Форум программистов, компьютерный форум, киберфорум
Firebird/InterBase
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
0 / 0 / 0
Регистрация: 17.09.2015
Сообщений: 1

Разбивка одного столбца на несколько

25.09.2012, 18:03. Показов 1539. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Проблема состоит в следующем: есть две таблицы Project и Budget связаны по полям Project.Id и Budget.Project. Нужно вывести название проекта (Project.Theme) и Budget.Amount. Тип связи между Project и Budget "один-ко-многим". При этом из столбца Budget.Amount необходимо доставать 4 записи и каждую из них помещать в отдельный столбец. Т.е. вот так:


"Project"
Id Theme
1 Проект_1
2 Проект_2


"Budget"
Amount Project Name
1000 1 Затраты_1
2000 1 Затраты_2
3000 1 Затраты_3
4000 1 Затраты_4
5000 2 Затраты_1
6000 2 Затраты_2
7000 2 Затраты_3
8000 2 Затраты_4
А результат такой:

Theme Затраты_1 Затраты_2 Затраты_3 Затраты_4
Проект_1 1000 2000 3000 4000
Проект_2 5000 6000 7000 8000
________________________________________ ________________________________

Пробовал сделать так:
SQL
1
2
3
4
5
6
SELECT Project.Theme,
    (SELECT Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_1'),
    (SELECT Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_2'),
    (SELECT Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_3'),
    (SELECT Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_4')
FROM Project
Выдает такую ошибку - "multiple rows in singleton select".
Подскажите, пожалуйста, в какую сторону смотреть.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.09.2012, 18:03
Ответы с готовыми решениями:

Разбивка данных из одного столбца в два
Добрый день Имеются два потока данных в одном столбце, время и показания прибора. Сохраняются они в ячейках A19-A2500 в следующем...

Разбивка одного текстового файла на несколько
Всем привет!) помогите пожалуйста , я хочу реализовать такую программу: Допустим имеется текстовый файл на 10231 строк. Надо...

Разделить данные из одного столбца в несколько
Есть набор данных (Пример данных.txt). Нужно разделить их по столбцам в excel в формате (Книга1) для последующего использования в matlab...

1
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
25.09.2012, 20:10
полагаю, что у вас в таблице "Budget" не именно такие строки, а есть дубли по полям Project+Name.
есть два варианта нейтрализовать их, но надо понимать, что это будут три неэквивалентных запроса:
SQL
1
2
3
4
5
6
SELECT Project.Theme,
 (SELECT FIRST 1 Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_1'),
 (SELECT FIRST 1 Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_2'),
 (SELECT FIRST 1 Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_3'),
 (SELECT FIRST 1 Budget.Amount FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_4')
 FROM Project
SQL
1
2
3
4
5
6
SELECT Project.Theme,
 (SELECT SUM(Budget.Amount) FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_1'),
 (SELECT SUM(Budget.Amount) FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_2'),
 (SELECT SUM(Budget.Amount) FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_3'),
 (SELECT SUM(Budget.Amount) FROM Budget WHERE Budget.Project=Project.Id AND Budget.Name='Затраты_4')
 FROM Project
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.09.2012, 20:10
Помогаю со студенческими работами здесь

Как скопировать из одного столбца в другие по несколько ячеек
Здравствуйте! Подскажите, пожалуйста, как решить такую задачу: Имеется один столбец "А" с множеством ячеек (конкретно в...

Трансформировать один большой столбец в таблицу (извлечь данные из одного столбца в несколько строк)
Привет всем. Искал подобные темы на форуме и в интернете, но не нашел. Возникла проблема с тем, что у меня есть данные, которые находятся в...

Разбивка столбца
Имеется таблица, в ней столбец, нужно этот столбец разчленить на два столбца, т.е. взять из данных, например, номер артикула в один столбец...

Разбивка List'a на несколько
Добрый вечер. Допустим у меня есть список из n элементов. Как мне его разбить на m списков по k элементов в каждом? (n = m*k)

Разбивка таблицы в WORD на несколько документов
Здравствуйте, поставили задачу разбить таблицу, которая создана в WORD (каталог) на отдельные документы *.doc. Объем грандиозный, а...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru