С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/34: Рейтинг темы: голосов - 34, средняя оценка - 5.00
2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 88
Записей в блоге: 1

Как сохранить несколько значений в одну строку?

26.07.2019, 14:18. Показов 6437. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Код sql:

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
  INSERT pWrongComment (SPID, LinkID, WrongType, WrongComment)          
  SELECT @@spid, -- Идентификатор пользователя
         LinkID, -- Идентификатор объекта
         1, 
         ' (Код типа объекта: ' 
       + CONVERT(VARCHAR(15), ObjectTypeCode) 
       + ', код атрибута: ' 
       + CONVERT(VARCHAR(15), WrongAttribute) 
       + ')'
    FROM pWrongAttrib
 
SELECT * FROM pWrongComment
SELECT * FROM pWrongAttrib
Результат выдачи данных:



Нам нужно чтобы (то, что выделил) разные LinkID записывать в один и тот же комментарий.

Результатом должно получится:

0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.07.2019, 14:18
Ответы с готовыми решениями:

PIVOT/UNPIVOT несколько значений из столбца в одну строку
Доброго времени суток! На форумах есть темы с подобным вопросом, где нужно значения из столбца поместить в одну строку в соответствии с...

Разбить одну строку на несколько
Ооочень нужна помощь!!!! Вот исходная таблица: ID Familia Ocenki 1 Иванов 2,4,3 2 Петров ...

Поделить одну строку на несколько
Добрый день! Мне необходимо поделить строку вида "aa bbb c" из таблицы 't1' на строки "aa", "bbb", "c",...

6
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
26.07.2019, 14:41
Цитата Сообщение от Teoscopion91 Посмотреть сообщение
Код sql
О какой СУБД идет речь?
0
2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 88
Записей в блоге: 1
26.07.2019, 14:59  [ТС]
Цитата Сообщение от Grossmeister Посмотреть сообщение
О какой СУБД идет речь?
MS SQL
0
Эксперт MS Access
 Аватар для ltv_1953
17536 / 7288 / 1663
Регистрация: 21.06.2012
Сообщений: 13,957
27.07.2019, 09:24
Цитата Сообщение от Teoscopion91 Посмотреть сообщение
MS SQL
Смотрите функцию STRING_AGG (возможно в Вашей версии ее и нет).
0
2 / 2 / 2
Регистрация: 23.03.2016
Сообщений: 88
Записей в блоге: 1
29.07.2019, 09:21  [ТС]
Функция не подойдет, нужен какой-либо вариант, который можно решить средствами sql языка, а не функциями возможной субд.

Я смотрел в сторону горизонтального начитывания, но тут возникает проблема, нам нужно заранее знать сколько данных мы будем начитывать, а их у нас будет случайное количество (от 1 до n).

Пример горизонтального начитывания
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
  SELECT CONVERT(VARCHAR(255), o.ObjectTypeCode)
         + ' / ' + (SELECT a.WrongAttribute
            FROM pWrongAttrib a
           WHERE a.SPID           = o.SPID
             AND a.LinkID         = o.LinkID
             AND a.ObjectTypeCode = o.ObjectTypeCode
             AND a.WrongAttribute = 15
         )
         + ' / ' + (SELECT a.WrongAttribute
            FROM pWrongAttrib a
           WHERE a.SPID           = o.SPID
             AND a.LinkID         = o.LinkID
             AND a.ObjectTypeCode = o.ObjectTypeCode
             AND a.WrongAttribute = 146
         )
         + ' / ' + (SELECT a.WrongAttribute
            FROM pWrongAttrib a
           WHERE a.SPID           = o.SPID
             AND a.LinkID         = o.LinkID
             AND a.ObjectTypeCode = o.ObjectTypeCode
             AND a.WrongAttribute = 1429
         )
  FROM pWrongAttrib o
WHERE o.SPID = @@spid
GROUP BY o.SPID, o.LinkID, o.ObjectTypeCode
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.07.2019, 10:32
Цитата Сообщение от Teoscopion91 Посмотреть сообщение
нужен какой-либо вариант, который можно решить средствами sql языка, а не функциями возможной субд.
А я думал, что все члены секты "универсальный sql-код" уже все повымерли...

Возможности универсального select, работающего на всех диалектах sql весьма ограничены. Поэтому, при текущем подходе, у вас всего две альтернативы:
а) таки пользоваться специфическими возможностями конкретной СУБД
б) делать нужную обработку на клиенте

Либо сделать редизайн, перенеся работу с СУБД в DAL. И уже в конкретном классе DAL пользоваться специфическими средствами СУБД.
0
2810 / 1679 / 885
Регистрация: 14.04.2015
Сообщений: 5,723
29.07.2019, 14:52
Teoscopion91, начиная с mssql server 2000, есть поддержка конкатенации строк через функцию FOR XML PATH.
и не надо огород городить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.07.2019, 14:52
Помогаю со студенческими работами здесь

Как объединить несколько линий в одну
Добрый, ест задача объединить несколько линий в одну. Искал в google и там есть примеры с XML Path. вещь хорошая но с моими данными не...

Как поместить в одну ячейку несколько результатов вывода?
Подскажите, есть ли такая возможность, переносить в одну ячейку несколько результатов вывода? Например: запрос выдал- ID 1 3 6...

Несколько значений в одну строку
Добрый день! Как объединить учетные номера в одну строку через точку с запятой, чтобы они не повторялись в отчете?

Разбить одну запись на несколько по текстовому полю с перечислением нескольких значений
Просьба помочь со следующей проблемой. В одном определенном текстовом поле записей базы данных находится переменное количество (от 1 до...

SLQ запрос выводит несколько раз одну и туже строку
День добрый. Запрос начал выдавать результат копируя строки и выдавая их по несколько раз. В какую сторону копать? В конце добавил...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru