私はDapperとマルチマッピングでCTEを使用してページングされた結果を得ようとしています。重複した列で不便を感じています。 CTEは、たとえば名前列を持たないようにしています。Dapperでのカスタムマッピング
次のクエリは、列名とプロパティの不一致ではなく、次のオブジェクトにマップしたいと考えています。
問合せ:
WITH TempSites AS(
SELECT
[S].[SiteID],
[S].[Name] AS [SiteName],
[S].[Description],
[L].[LocationID],
[L].[Name] AS [LocationName],
[L].[Description] AS [LocationDescription],
[L].[SiteID] AS [LocationSiteID],
[L].[ReportingID]
FROM (
SELECT * FROM [dbo].[Sites] [1_S]
WHERE [1_S].[StatusID] = 0
ORDER BY [1_S].[Name]
OFFSET 10 * (1 - 1) ROWS
FETCH NEXT 10 ROWS ONLY
) S
LEFT JOIN [dbo].[Locations] [L] ON [S].[SiteID] = [L].[SiteID]
),
MaxItems AS (SELECT COUNT(SiteID) AS MaxItems FROM Sites)
SELECT *
FROM TempSites, MaxItems
オブジェクト:命名規則が私のために、このシナリオを処理しますが、私は言及を見つけることができない存在していることを、私は私の頭の中でそれを持っているいくつかの理由
public class Site
{
public int SiteID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public List<Location> Locations { get; internal set; }
}
public class Location
{
public int LocationID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public Guid ReportingID { get; set; }
public int SiteID { get; set; }
}
それはドキュメントの中にあります。
私はこの質問を終了しようとしましたが、オープンバウンティです。これは複製です。 ITypeMapインターフェイスと属性を使用する必要があります。ここをクリックしてください:http://stackoverflow.com/questions/8902674/manually-map-column-names-with-class-properties –