相关疑难解决方法(0)

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

我找到了使用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字符串进行此查询?

c# sql sql-server dapper

6
推荐指数
1
解决办法
266
查看次数

处理程序将字符串映射到dapper中的varchar

我发现这些代码在精致:

sealed partial class DbString : Dapper.SqlMapper.ICustomQueryParameter
{
    ...

    public void AddParameter(IDbCommand command, string name)
    {
        ...
        var param = command.CreateParameter();
        param.ParameterName = name;
        param.Value = (object)Value ?? DBNull.Value;
        if (Length == -1 && Value != null && Value.Length <= 4000)
        {
            param.Size = 4000;
        }
        else
        {
            param.Size = Length;
        }
        ...
    }
}
Run Code Online (Sandbox Code Playgroud)

你能告诉我为什么这里的代码需要将长度与4000进行比较吗?

谢谢.

dapper

5
推荐指数
1
解决办法
2194
查看次数

用于 varchar 的 DbString、IsFixedLength 和 IsAnsi

我是 Dapper 的新手,想知道为什么在我的代码在没有它的情况下运行时会建议以下建议?

Ansi 字符串和 varchar

Dapper 支持 varchar 参数,如果您使用参数在 varchar 列上执行 where 子句,请确保以这种方式传递它:

 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)

在 SQL Server 上,查询 unicode 时使用 unicode 和查询非 unicode 时使用 ansi 至关重要。

下面是我的代码,它在不使用 DbString 等的情况下针对 SQL Server 2012 运行。

create table Author (
 Id int identity(1,1),
 FirstName varchar(50),
 LastName varchar(50)
);
go
insert into Author (FirstName, LastName) values ('Tom', …
Run Code Online (Sandbox Code Playgroud)

dapper

5
推荐指数
1
解决办法
2620
查看次数

标签 统计

dapper ×3

c# ×1

sql ×1

sql-server ×1