好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

c# – 当sqlchars和sqlstring时?

我正在用c#开发一个CLR应用程序.

我遇到SqlChars类型和SqlString.

但我没有发现它们之间的区别.

什么时候使用SqlChars并使用SqlString?

谢谢

我为复制当前所选答案中的一些数据而道歉,但我想尝试提供一点澄清.

首先,答案简短:

我对何时使用SqlChars vs SqlString的建议与你的意图有关.如果您不打算修改输入字符串,请使用SqlString.如果需要操作输入,请使用SqlChars.

现在有一些关于我如何到达那里的细节:

我们可以从文档中看到SqlChars是一个类,而SqlString是一个结构.类与结构超出了此响应的范围,但足以说结构的重量更轻.您还可以看到SqlChars是可变的(您可以更改它而无需新的内存分配).我找不到涉及SqlString大小限制的文档,并且使用大于VARCHAR(8000)/ NVARCHAR(4000)的数据和SqlString没有任何问题.如果您遇到问题,请确保您的CLR代码具有MaxByteSize = -1.

以下信息来自SQL Types的MSDN文档.

SqlChars is a mutable reference type that wraps a Char array or a SqlString instance.

结构

SqlString – Represents a variable-length stream of characters to be stored in or retrieved from the database. SqlString has a different underlying data structure from its corresponding .NET Framework String data type.

查看更多关于c# – 当sqlchars和sqlstring时?的详细内容...

  阅读:42次