C#:DbType.String与DbType.AnsiString

我接管了一些C#代码。

代码使用一些使用参数的SQL来访问数据库。

所有字符串参数都输入为DbType.AnsiString而不是DbType.String

为什么要使用DbType.AnsiString而不是DbType.String

AnsiString类型
可变长度的非Unicode字符流,范围在1到8,000个字符之间。


表示Unicode字符串的类型。

在数据库中:

nchar和nvarchar是unicode

char和varchar是非unicode

您将使用ansistring而不是字符串来避免SQL Server数据库中的隐式转换。

即,当您将字符串变量传递给MSSQL时,它显示为nvarchar(max)。 鉴于设计良好的数据库默认情况下可能使用varchars而不是nvarchars(除非对非拉丁字符集有业务要求)。

在这种情况下,字符串变量将导致数据库中的隐式转换。 然后,这可以使引擎无法使用某些索引并执行全表扫描(数据库性能的所有恶意之一)