Csharp/C#教程:C#:DbType.String与DbType.AnsiString分享


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(除非对非拉丁字符集有业务要求)。

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

上述就是C#学习教程:C#:DbType.String与DbType.AnsiString分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/958668.html

(2)
上一篇 2021年11月22日
下一篇 2021年11月22日

精彩推荐