代码之家  ›  专栏  ›  技术社区  ›  Matt Spinks

如何告诉dapper对使用“in”的“where”子句中的参数列表使用varchar?

  •  5
  • Matt Spinks  · 技术社区  · 7 年前

    我找到了使用dapper搜索 VARCHAR 使用字段 string 作为输入:

    Query<Thing>("select * from Thing where Name = @Name", new {Name = 
    new DbString { Value = "abcde", IsFixedLength = true, Length = 10, IsAnsi = true });
    

    资料来源: Dapper and varchars

    但是有没有办法让它适应 DbString 列表中每个项的转换(使用in子句)?

    我试图运行的查询如下所示:

    Query<IndexRec>("SELECT * FROM T_INDEX WHERE CallId IN @callIds",
    new { callIds = model.LogEntries.Select(x => x.Id) });
    

    不幸的是,此查询运行缓慢,因为:

    1. model.LogEntries 包含大约300个项目。
    2. t_index.callid是 VARCHAR(30) 字段。
    3. 据我所知,衣冠楚楚 NVarchar 在一个 WHERE 违约条款。
    4. 这会导致在sql中对表中的每一行进行隐式转换,从而大大降低查询速度。

    如何告诉dapper在我的 IN 此查询的子句?

    1 回复  |  直到 7 年前
        1
  •  6
  •   DavidG    7 年前

    你应该可以把 DbString 项目,例如:

    var parameters = model.LogEntries
        .Select(x => new DbString 
        {
            Value = x.Id, 
            IsAnsi = true
        });
    
    Query<IndexRec>("SELECT * FROM T_INDEX WHERE CallId IN @callIds", new { callIds = parameters })