Dapper参数长度

时间:2018-02-10 16:19:29

标签: sql-server tsql dapper

不确定这是否与Dapper的使用有关。在使用Dapper的SQL Server上,我看到生成了多个缓存的计划,唯一的区别是参数的长度:

(@parentId uniqueidentifier,@childName nvarchar(60)) 
 SELECT [ID] FROM [Items] WHERE [ParentID] = @parentId AND [Name] = @childName

(@parentId uniqueidentifier,@childName nvarchar(91))
SELECT [ID] FROM [Items] WHERE [ParentID] = @parentId AND [Name] = @childName

(@parentId uniqueidentifier,@childName nvarchar(15))
 SELECT [ID] FROM [Items] WHERE [ParentID] = @parentId AND [Name] = @childName

是否有任何控制参数长度的Dapper配置设置?是否可以将其设置为与表列定义匹配的固定长度nvarchar(256)

1 个答案:

答案 0 :(得分:3)

您可以在传递参数时定义长度:

new {childName = new DbString { Value = "SomeValue", Length = 256, 
                               IsAnsi = false, IsFixedLength = false }};