Linqtosql - соединенные строки

Как в Linqtosql показать элементы из нескольких строк в одном поле.

Например, у меня есть 3 таблицы для тегирования (объект, тег, entitytag), все они связаны через внешние ключи.

Для каждого объекта я хотел бы вернуть имя в одном поле, а затем все соответствующие теги во втором поле.

например, Item1, tag1; tag2; tag3 Item2, tag4, tag5 ....

Заявления VB предпочтительнее.

Спасибо Джефф

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
0
112
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Ладно, не уверен, что это наиболее эффективный способ, но он работает.

Dim dc As New DataContext

Dim query = From i In dc.Items _
            Let tags = (From t In dc.ItemTags _
                        Where t.ItemID = i.ID _
                        Select t.Tag.Name).ToArray _
            Select i.ItemName, Tags = String.Join(" | ", tags)

Для того, что вы пытаетесь сделать, это лучший способ, который я могу придумать.

Adam Lassek 24.11.2008 20:29

С этим ответом я предполагаю, что у вас есть настройки таблиц, аналогичные приведенным ниже, имена не очень хороши, просто для иллюстрации:

AnEntity: Id, Name
ATag: Id, TagName
EntityTag: EntityId (от FK до AnEntity.Id), TagId (от FK до ATag.Id)

Вы можете попробовать это:

var entityTags = from ent in theEntities
                 from enttags in ent.EntityTags
                 group enttags by enttags.AnEntity into entityGroup
                 select new { TheEntity = entityGroup.Key, TheTags = 
                              from t in entityGroup
                              select t.ATag.TagName };

У меня не было возможности проверить это, я попробую сегодня днем ​​и отредактирую, если потребуется. Здесь происходит SelectMany. «From ent in dc.AnEntities» получает все записи сущностей, затем следующий «from enttags в ent.EntityTags» получает все записи тегов сущностей для каждой сущности. Группа by делает это в значительной степени, группирует записи EntityTag по AnEntity. Поместите их в анонимный тип, и все готово.

ИЗМЕНИТЬ:
Хорошо, изменил код выше, теперь он работает. Прежде чем вы получите список объектов EntityTag, теперь вы получаете объект Entiy и список строк (тегов) для этой сущности.

Другие вопросы по теме