亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

用逗號分隔變量內的多個列值連接

用逗號分隔變量內的多個列值連接

C#
撒科打諢 2022-10-23 15:04:06
我有一個查詢linq-to-sql如下:var query = (from users in _context.Users             join consumers in _context.Consumers             on users.usersId equals consumers.consumerId             from clients in _context.Clients.Where(x => x.Id == users.Id).DefaultIfEmpty().Take(1)            where consumerId.Contains(consumers.consumerId)            select new UserConsumerDto             {             FirstName = users.FirstName,              LastName = users.LastName,              ClientName = clients.Name            }).ToList()上面的查詢返回了幾行;這意味著一個用戶可以有多個客戶端。因此,我添加Take(1)了暫時只獲得一個客戶?,F在,當我刪除 時Take(1),會返回幾條記錄。我想通過用逗號分隔的用戶在單個記錄中添加客戶端名稱來避免這種情況。例如:User 1 | ClientA, ClientB 代替:User 1 | Client AUser 1 | Client B有人可以幫我實現這一目標嗎?
查看完整描述

2 回答

?
慕尼黑5688855

TA貢獻1848條經驗 獲得超2個贊

例如,您可以使用group by對記錄進行分組UserName,然后聚合客戶端名稱,string.Join(",",ClientName)用于連接客戶端名稱。

這是一個示例代碼:


    var userClients = from c in (dbContext joined tables)

      group c by c.UserName into u 

      select new {

          UserName = u.First().UserName,

          ClientName = string.Join(",", (from n in u select n.ClientName).ToArray()) 

      };

檢查此演示中的示例代碼


查看完整回答
反對 回復 2022-10-23
?
瀟湘沐

TA貢獻1816條經驗 獲得超6個贊

你可以試試這段代碼


SELECT DISTINCT ST2.SubjectID, 

    SUBSTRING(

    (

    SELECT ','+ST1.StudentName AS [text()]

    FROM dbo.Students ST1

    WHERE ST1.SubjectID = ST2.SubjectID

    ORDER BY ST1.SubjectID

    FOR XML PATH ('')

    ), 2, 1000) [Students]

    FROM dbo.Students ST2

供參考檢查


查看完整回答
反對 回復 2022-10-23
  • 2 回答
  • 0 關注
  • 96 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號