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(除非对非拉丁字符集有业务要求)。
在这种情况下,字符串变量将导致数据库中的隐式转换。 然后,这可以使引擎无法使用某些索引并执行全表扫描(数据库性能的所有恶意之一)