我找到了使用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) });
不幸的是,此查询运行缓慢,因为:
-
model.LogEntries
包含大约300个项目。
-
t_index.callid是
VARCHAR(30)
字段。
-
据我所知,衣冠楚楚
NVarchar
在一个
WHERE
违约条款。
-
这会导致在sql中对表中的每一行进行隐式转换,从而大大降低查询速度。
如何告诉dapper在我的
IN
此查询的子句?