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

要回复问题请先登录注册