如何告诉Dapper使用varchar作为使用"IN"的"WHERE"子句中的params列表?

Mat*_*nks 6 c# sql sql-server dapper

我找到了使用Dapper VARCHAR使用string输入搜索字段的解释和解决方案:

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

资料来源:Dapper和varchars

但有没有办法调整它来DbString为列表中的每个项目进行转换(使用IN子句)?

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

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

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

  1. model.LogEntries 包含约300项.
  2. T_INDEX.CallId是一个VARCHAR(30)字段.
  3. 据我所知,Dapper 默认使用子句中的NVarchar字符串WHERE.
  4. 这会导致在SQL中对表中的每一行进行隐式转换,这会显着降低查询速度.

如何告诉Dapper在我的IN子句中使用ansi字符串进行此查询?

Dav*_*idG 6

您应该能够传入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 })
Run Code Online (Sandbox Code Playgroud)