c# – 如何告诉Dapper使用varchar作为使用“IN”的“WHERE”子句中的params列表?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 如何告诉Dapper使用varchar作为使用“IN”的“WHERE”子句中的params列表?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含977字,纯文字阅读大概需要2分钟。
内容图文
我找到了使用Dapper使用字符串作为输入搜索VARCHAR字段的解释和解决方案:
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)字段.
>据我所知,默认情况下,Dapper在WHERE子句中使用NVarchar和字符串.
>这会导致在SQL中对表中的每一行进行隐式转换,这会显着降低查询速度.
如何告诉Dapper在我的IN子句中使用ansi字符串进行此查询?
解决方法:
您应该能够传入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 })
内容总结
以上是互联网集市为您收集整理的c# – 如何告诉Dapper使用varchar作为使用“IN”的“WHERE”子句中的params列表?全部内容,希望文章能够帮你解决c# – 如何告诉Dapper使用varchar作为使用“IN”的“WHERE”子句中的params列表?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。