精致无限的多映射

 尕心疼TammyY 发布于 2023-02-13 07:53

所以我有一种情况,我必须加入(并映射)超过7个实体(据我所知,这是Dapper的当前限制).这是我到目前为止(伪代码):

using (var connection = new SqlConnection(_connectionString)) {
   IEnumerable results = 
      connection.Query(sql, 
         (b, l1, l2, l3) => {
            // map and return here
         },
         splitOn: "split1, split2 ...");
}

这种限制有什么办法吗?以前有人面对这个吗?也许一些Dapper扩展?

2 个回答
  • 目前我所知道的唯一两种方法是解决这个问题

    使用所需的字段创建POCO类,并像表一样使用查询

    修改Dapper的源代码以允许更多映射.

    2023-02-13 07:57 回答
  • 2014年9月,该主题有一个合并的公关:

    https://github.com/StackExchange/Dapper/pull/158/files

    PR添加了可以传递类型数组的方法.因此,对这些方法不再存在对7个实体的限制.

    这是来自Dapper Repo的代码测试,展示了如何使用以下新方法之一:

    public async Task TestMultiMapArbitraryWithSplitAsync()
        {
            const string sql = @"select 1 as id, 'abc' as name, 2 as id, 'def' as name";
            var productQuery = await connection.QueryAsync<Product>(sql, new[] { typeof(Product), typeof(Category) }, (objects) => {
                var prod = (Product)objects[0];
                prod.Category = (Category)objects[1];
                return prod;
            });
    
            var product = productQuery.First();
            // assertions
            product.Id.IsEqualTo(1);
            product.Name.IsEqualTo("abc");
            product.Category.Id.IsEqualTo(2);
            product.Category.Name.IsEqualTo("def");
        }
    

    2023-02-13 07:58 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有