我找到了使用Dapper使用VARCHAR
作为输入来搜索string
字段的说明和解决方案:
Query<Thing>("select * from Thing where Name = @Name", new {Name =
new DbString { Value = "abcde", IsFixedLength = true, Length = 10, IsAnsi = true });
但是有没有办法使它适应列表中的每个项目(使用IN子句)进行DbString
转换?
我要运行的查询如下:
Query<IndexRec>("SELECT * FROM T_INDEX WHERE CallId IN @callIds",
new { callIds = model.LogEntries.Select(x => x.Id) });
不幸的是,此查询运行缓慢,原因是:
model.LogEntries
包含大约300个项目。 VARCHAR(30)
字段。NVarchar
子句中使用WHERE
和字符串。 如何告诉Dapper针对此查询在IN
子句中使用ansi字符串?
答案 0 :(得分:5)
您应该能够传递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 })