我有建立表,如下所示,
EstabId Name CheckinDate
114883 Marconfort Griego Hotel 2011-09-28 00:00:00.000
114910 Royal Costa Hotel 2011-10-18 00:00:00.000
114912 Roc Flamingo Hotel 2011-11-22 00:00:00.000
114912 Roc Flamingo Hotel 2011-11-29 00:00:00.000
114912 Roc Flamingo Hotel 2011-12-06 00:00:00.000
114912 Roc Flamingo Hotel 2011-12-13 00:00:00.000
114912 Roc Flamingo Hotel 2011-12-20 00:00:00.000
114894 Gran Hotel Blue Sea 2012-01-17 00:00:00.000
114894 Gran Hotel Blue Sea 2012-01-31 00:00:00.000
假设,如果我想构建我的查询结果,
Response : {
[
EstabId: 114912,
Name: 'Roc Flamingo Hotel',
CheckinDates : [2011-11-22 00:00:00.000, 2011-11-29 00:00:00.000, 2011-12-06 00:00:00.000, 2011-12-13 00:00:00.000, 2011-12-20 00:00:00.000]
,... ]
}
是否有任何建议的方式从SQL Stored Procedure
或C# + SQL combination
实现此结构?
PS:我听说,SQL SERVER不支持List
任何回复都将受到高度赞赏。
答案 0 :(得分:0)
这可能有用。但是,您还应该阅读this文章以了解具体需求。
此查询将以逗号分隔的签入日期返回结果,您可以将其存储在Establishment类的集合中。
SELECT es1.EstabId , es2.Name ,
(
SELECT @CheckInDateList = COALESCE(@CheckInDateList +',' ,'') + CheckinDate
FROM Establishment es2
WHERE
es2.EstabId = es1.EstabId
AND
es2.Name = es1.Name
) as CheckinDates
FROM Establishment es1
答案 1 :(得分:-1)
你可以创建一个这样的类
public class Checkins
{
public int EstabId { get; set; }
public string Name { get; set; }
public List<DateTime> CheckInDates { get; set; }
}
然后创建一个Checkin实例并从Databse填充数据。最后序列化此实例以获得预期结果。