了解SQLServer中varchar(max)、nvarchar(max)和varbinary(max)
了解SQLServer中varchar(max)、nvarchar(max)和varbinary(max) 转载于:http://www.poorren.com/sqlserver-2005-varcharmax-nvarcharmax-varbinarymax/comment-page-1/
在Microsoft SQLServer2005及以上的版本中,对于varchar(n)、nvarchar(n)和varbinary(n)有了max的扩展。可以使用如:varchar(max)、nvarchar(max)和varbinary(max)的大值数据类型来存储最多2^30-1个字节的数据。 这几个数据类型在行为上和较小的数据类型 varchar、nvarchar 和 varbinary 相同。 以varchar为例,varchar支持8000字符,Text支持2GB字符,但是,替换函数在编写出来的时候,就对TEXT数据类型不起作用。 同样也对CHARINDEX或者SUBSTRING不起作用——或者至少是他们在超过8千个字符的情况下不起作用。更进一步地讲,如果开发人员忘了处理TEXT或者IMAGE类型的本地变量,则实际上不支持任何操作。即使是简单地更新一个文档中的一个子字符串都需要用到很多的东西,以及难以使用的类似READTEXT和WRITETEXT的函数。 SQL Server 2005引入了一系列新的被称为max的数据类型(或者说是参数类型)。这是varchar、nvarchar 和 varbinary类型的扩展,这几种类型以前被限制在8000字节以下。max可以容纳高达2GB的数据,与TEXT和IMAGE一样——并且完全兼容所有的SQL Server内置的字符串函数。 用max关键字定义一个某种max类型的变量与替代字符串的尺寸(为varchar、nvarchar的时候)或者字节(为varbinary的时候)一样简单。 DECLARE @BigString varchar(max) 虽然这个变量可以自由地操纵,并且可以传递给任何的内置的字符串函数,兼容性仍然不是没有问题。首先,开发人员不能期望指定了尺寸的varchar和nvarchar变量在达到8000个字节的极限的时候可以自动“升级”到max版本。例如,如下的批处理: @String1(4001@String2) 4001+4001=8002,但是指定了尺寸的varchar的极限是8000。因为这两个变量中没有一个是max类型,LEN函数的结果就是8000,不是8002。在将两个变量连接的时候,一种简单的修正方法就是声明这两个变量中的一个为varchar(max)或者将其中的一个变量进行转换。与一个规定了尺寸的类型进行连接的时候,优先考虑max类型,最终结果是max类型。所以,以下批处理的结果是8002,正如我们期望的一样: CONVERTvarchar),145)">@String1 在传递给字符串函数的时候,开发人员意识到字符串的原意在默认情况下是规定了尺寸的,而不是max类型,也是至关重要的。例如,以下查询的结果就很令人惊奇:REPLICATE8002)) 因为字符串‘1’是被作为规定了尺寸的varchar对待,而不是varchar(max),结果就是8000——但是在SQL Server 2005中,REPLICATE函数能够产生高达2GB的字符串。要修正这个问题,可以将字符串转换为varchar(max),这样函数就会输出同样的类型了: 这个查询现在将会返回期望的结果:8002。记住,总是要对采用了新特性编写的代码进行非常仔细的测试;隐藏的问题,例如上面描述的问题,可能并且毫无疑问地会在最坏的时间里造成灾难性的后果。 EXEC sp_tableoption 扩展: 既然是以max有这么多灵活性,一些数据库设计师将会被引诱以下列的方式开始定义表: CREATE TABLE Addresses( 总知,max标记的数据类型为SQL Server 2005及之后版本处理大数据增加了很大部分的灵活性,但在使用中需要自己根据需求选择字段类型。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |