嵌套多映射Dapper分页查询中的重复字段名称问题

时间:2011-09-14 11:26:06

标签: c# .net orm dapper

尝试使用Dapper进行多映射时遇到了分页查询问题。

因为我在这个分页场景中使用嵌套查询,所以嵌套查询中有多个表我必须加入以获取我的多映射数据,但是这些表中的一些将共享一些与您同名的字段我可以在下面的示例查询中看到(例如iddisplaynameemail):

q = @"select * from (select p.id, p.title, p.etc...,
u1.id, u1.displayname, u1.email,
u2.id, u2.displayname, u2.email,
t.id, t.name,
row_number() over (order by " + sort.ToPostSortSqlClause() + ") as rownum" +
" from posts p" +
" join users u1 on p.owneruserid = u1.id" +
" join users u2 on p.lastediteduserid = u2.id" +
" join topics t on p.topicid = t.id" +
") seq where seq.rownum between @pLower and @pUpper";

在上面的示例中,您可以看到在嵌套查询中,字段id会出现问题(显示在posts表中,两个users表连接和topics表连接,以及displaynameemail(显示在users表连接中)。

到目前为止我唯一想到的解决方法是将这些“问题”字段作为一个不同的名称进行转换,但这涉及在受影响的模型中创建虚拟属性的非常混乱的过程,因此多重映射可以映射到这些,并编辑模型中的“真实”属性,如果尚未设置实际值,还要检查虚拟属性值。

此外,在上面的场景中,我将不得不创建x虚拟属性,其中x是我在查询中的同一个表上可能具有的连接数(在此示例中,2个连接在同一个Users表上,因此需要2个唯一命名的虚拟属性,仅用于Dapper映射目的)。

这显然不太理想,我确信在创建更多这些多映射分页查询时会遇到问题和更多的不整洁。

我希望这个问题有一个很好的,干净的解决方案吗?

1 个答案:

答案 0 :(得分:1)

我能想到两个选项:

选项1 :联接回嵌套查询之外的扩展属性:

select s.*, t1.*, t2.* from 
(
select s.*, ROW_NUMBER() OVER (order by somecol) AS RowNumber from Something s
) as X 
left join Table t1 on Id = x.SomeId
left join Table t2 on Id = x.SomeOtherId

选项2 :扩展SqlBuilder以处理列别名:

select s.*, /**unalias(Table,t1)**/, /**unalias(Table,t2)**/ from 
        (
        select s.*, /**alias(Table,t1)**/, /**alias(Table,t2)**/ ROW_NUMBER() OVER (order by somecol) AS RowNumber from Something s
        left join Table t1 on Id = x.SomeId
        left join Table t2 on Id = x.SomeOtherId
        ) as X 

然后使用INFORMATION_SCHEMA.COLUMNS定义别名宏以查询和缓存数据库中的列列表,并为每列添加“column as column_t1”字符串。

Unalias可以很简单地做到相反。