如何在SQL Server中获取List <columntype>?</columntype>

时间:2014-11-19 09:23:36

标签: c# sql sql-server

我有建立表,如下所示,

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 ProcedureC# + SQL combination实现此结构?

PS:我听说,SQL SERVER不支持List

任何回复都将受到高度赞赏。

2 个答案:

答案 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填充数据。最后序列化此实例以获得预期结果。