繁体   English   中英

sql server中varchar(500)和varchar(max)的区别

[英]difference between varchar(500) vs varchar(max) in sql server

我想知道在性能、内存和其他需要考虑的方面,使用 varchar(500) 与 varchar(max) 的优缺点是什么?

  • 两者会使用相同数量的存储空间吗?

在 sql server 2000/2005/2008 的情况下,答案是否不同?

在 SQL Server 2000 和 SQL Server 7 中,一行的大小不能超过 8000 字节。 这意味着一个 VARBINARY 列只能存储 8000 个字节(假设它是表中唯一的列),一个 VARCHAR 列最多可以存储 8000 个字符,一个 NVARCHAR 列最多可以存储 4000 个字符(每个 unicode 字符 2 个字节)。 此限制源于 SQL Server 用于将数据保存到磁盘的 8 KB 内部页面大小。

要在单个列中存储更多数据,您需要使用 TEXT、NTEXT 或 IMAGE 数据类型 (BLOB),这些数据类型存储在 8 KB 数据页的集合中,这些数据页与在列中存储其他数据的数据页是分开的。同一张桌子。 这些数据页以 B 树结构排列。 BLOB 很难使用和操作。 它们不能在过程或函数中用作变量,也不能在字符串函数(如 REPLACE、CHARINDEX 或 SUBSTRING)中使用。 在大多数情况下,您必须使用 READTEXT、WRITETEXT 和 UPDATETEXT 命令来操作 BLOB。

为了解决这个问题,Microsoft 在 SQL Server 2005 中引入了 VARCHAR(MAX)、NVARCHAR(MAX) 和 VARBINARY(MAX) 数据类型。这些数据类型可以容纳 BLOB 可以容纳的相同数量的数据(2 GB),它们是存储在相同类型的数据页中,用于其他数据类型。 当 MAX 数据类型中的数据超过 8 KB 时,使用溢出页面。 SQL Server 2005 自动为页面分配一个溢出指示器,并且知道如何像处理其他数据类型一样处理数据行。 您可以在存储过程或函数中声明 MAX 数据类型的变量,甚至可以将它们作为变量传递。 您也可以在字符串函数中使用它们。

Microsoft 建议在 SQL Server 2005 中使用 MAX 数据类型而不是 BLOB。事实上,在 SQL Server 的未来版本中,BLOB 已被弃用。

信用: http : //www.teratrax.com/articles/varchar_max.html


在 SQL Server 2005和 SQL Server 2008 中,VARCHAR(MAX) 的最大存储大小为 2^31-1 字节(2,147,483,647 字节或 2GB - 1 字节)。 存储大小为输入数据的实际长度+2 个字节。 输入的数据长度可以为 0 个字符。 由于 VARCHAR 数据类型中的每个字符使用一个字节,因此 VARCHAR(MAX) 数据类型的最大长度为 2,147,483,645。

完整有趣的阅读: http : //www.sql-server-helper.com/faq/sql-server-2005-varchar-max-p01.aspx

参考: http : //msdn.microsoft.com/en-us/library/ms143432.aspx

VARCHAR(MAX)列将接受 501 个或更多字符的值,而VARCHAR(500)列则不会。 因此,如果您有将值限制为 500 个字符的业务规则,则VARCHAR(500)将更合适。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM