SQL NVARCHAR和VARCHAR限制
1:NVARCHAR(max)可以存储(有时甚至更多)2GB的数据(10亿个双字节字符)。
2:NVARCHAR和VARCHAR连接时的截断取决于数据类型
varchar(n) + varchar(n)只能容纳8000个字符,超过部分将被截断。nvarchar(n) + nvarchar(n)只能容纳4000个字符,超过部分将被截断。varchar(n) + nvarchar(n)只能容纳4000个字符,超过部分将被截断。因为nvarchar具有较高的优先级,所以结果是nvarchar(4000)[n]varchar(max)+[n]varchar(max)不会被截断(<2GB)。varchar(max)+varchar(n)不会被截断(<2GB),结果将会输出varchar(max)。varchar(max)+nvarchar(n)不会被截断(<2GB),结果将会输出nvarchar(max)。nvarchar(max)+varchar(n)首先将varchar(n)输入转换为nvarchar(n)然后进行连接。如果varchar(n)字符串的长度 大于4000个字符,则转换为nvarchar(4000)并且将长度超过4000的部分截断。
3:字符串文字的数据类型
- 字符串的长度<=8000的字符串数据类型将被视为varchar(n)。例如:
'Foo'将被视为varchar(3)。 - 字符串的长度>8000的字符串数据类型将被视为varchar(max)。
- 使用'N'前缀并且字符串的长度<=4000的字符串数据类型将被视为nvarchar(n)。例如:
N'Foo'将被视为nvarchar(3)。 - 使用'N'前缀并且字符串的长度>4000的字符串数据类型将被视为nvarchar(max)。
- 于上述两者,如果字符串的长度为0,则n设置为1。
-- ======================================================
-- 1:VARCHAR(n)类型最多只能容纳8000个字符(非字)
-- 同时验证varchar(n) + varchar(n)这种方式只能容纳8000个字符
-- ======================================================
/*1.1VARCHAR(9000)这样超过最大长度的定义方式会报错*/
--DECLARE @VARCHAR_N VARCHAR(9000); //报错,无法执行 /*1.2即使定义合法,但是在后面的赋值操作中如果超过8000
的长度照样会截断(只保留8000个字符的长度)*/
DECLARE @VARCHAR_N VARCHAR(8000) = '';
DECLARE @Sum INT,@Counter INT
SET @Sum = 8005
SET @Counter = 0;
WHILE(@Counter < @Sum)
BEGIN
IF(@Counter < 8000)
BEGIN
SET @VARCHAR_N = @VARCHAR_N + 'A'
END
ELSE
BEGIN
SET @VARCHAR_N = @VARCHAR_N + 'B'
END
SET @Counter = @Counter + 1;
END
PRINT LEN(@VARCHAR_N) --只能输出8000个字符
PRINT @VARCHAR_N --只会输出A,不会输出B -- ======================================================
-- 2:VARCHAR(n)类型最多只能容纳4000个字
-- ======================================================
DECLARE @VARCHAR_N VARCHAR(8000) = '';
DECLARE @Sum INT,@Counter INT
SET @Sum = 8005
SET @Counter = 0;
WHILE(@Counter < @Sum)
BEGIN
IF(@Counter < 4000)
BEGIN
SET @VARCHAR_N = @VARCHAR_N + '中'
END
ELSE
BEGIN
SET @VARCHAR_N = @VARCHAR_N + '国'
END
SET @Counter = @Counter + 1;
END
PRINT LEN(@VARCHAR_N) --只能输出4000个字
PRINT @VARCHAR_N --只会输出'中',不会输出'国' -- ======================================================
-- 3:NVARCHAR(n)类型最多只能容纳4000个字,跟2的差不多
-- 同时验证NVARCHAR(n) + NVARCHAR(n)这种方式只能容纳4000个字符
-- ======================================================
DECLARE @NVARCHAR_N NVARCHAR(4000) = '';
DECLARE @Sum INT,@Counter INT
SET @Sum = 4005
SET @Counter = 0;
WHILE(@Counter < @Sum)
BEGIN
IF(@Counter < 4000)
BEGIN
SET @NVARCHAR_N = @NVARCHAR_N + '中'
END
ELSE
BEGIN
SET @NVARCHAR_N = @NVARCHAR_N + '国'
END
SET @Counter = @Counter + 1;
END
PRINT LEN(@NVARCHAR_N) --只能输出4000个字
PRINT @NVARCHAR_N --只会输出'中',不会输出'国'
SQL NVARCHAR和VARCHAR限制的更多相关文章
- SQL Server char,varchar,nchar,nvarchar区别
SQL Server char,varchar,nchar,nvarchar区别 (1) 定义: char: 固定长度,存储ANSI字符,不足的补英文半角空格. nchar: 固 ...
- char、nvarchar和varchar区别
这3种字符串数据类型是我们使用最多的,我们在数据库设计时到底该怎么使用了?首先我们先来分析3个数据类型的说明: 1.char CHAR的长度是固定的,最长2000个字符. 2.varchar 和 va ...
- nvarchar 和varchar区别
有时候设计字段的时候,碰到nvarchar和varchar时候,是有点犹豫.所以今天就来探个究竟把. (一) varchar是非Unicode可变长度类型,nvarchar是Unicode编码可变长 ...
- 怎么区分MSSQL中nvarchar和varchar的区别?
怎么区分MSSQL中nvarchar和varchar的区别呢?下面两段代码可以帮你看到他们的区别. declare @s Nvarchar(10) set @s='那么相当于abcd可以存储多少个汉字 ...
- SQL 中nvarchar和varchar到底能存多少汉字和英文
实践出真知,在SQL中,nvarchar(50)表示汉字和英文都是50,varchar(50)汉字25,英文50
- 英文操作系统中中文乱码(SQL中 NVARCHAR 和 VARCHAR区别)
varchar在SQL Server中是采用单字节来存储数据的,nvarchar是使用Unico来存储数据的.中文字符存储到SQL Server中会保存为两个字节(一般采用Unico编码),英 ...
- SQL Server中,varchar和nvarchar如何选择
正常情况下,我们使用varchar也可以存储中文字符,但是如果遇到操作系统是英文操作系统并且对中文字体的支持不全面时, 在SQL Server存储中文字符为varchar就会出现乱码(显示为??). ...
- sql nvarchar类型和varchar类型存储中文字符长度
今天遇到了,随手记录一下. sql server 存储数据里面 NVARCHAR 记录中文的时候是 一个中文对应一个字符串长度,记录英文也是一个字母一个长度 标点符号也是一样. ...
- SQL Server中VARCHAR(MAX)和NVARCHAR(MAX)使用时要注意的问题(转载)
在Microsoft SQLServer2005及以上的版本中,对于varchar(n).nvarchar(n)和varbinary(n)有了max的扩展.可以使用如:varchar(max).nva ...
随机推荐
- ElasticSearch的概念解析
ElasticSearch是面向文档的,它不仅仅可以存储整个对象或则文档(document),还会索引(index)每个文档的内容使它可以被快速的检索.ElasticSearch和关系型数据库的对比如 ...
- zookeeper集群环境搭建详细图文教程
zookeeper集群环境搭建详细图文教程 zhoubang @ 2018-01-02 [文档大纲] 友情介绍 软件环境 注意点 环境安装 1. 新建用于存储安装包以及软件安装的目录 2. 下载安装z ...
- layer_mobile的简单使用
layer mobile弹层组件是为移动设备(手机.平板等webkit内核浏览器/webview)量身定做的弹层UI. 由于是采用原生 JavaScript编写,所以并不依赖任何第三方库. layer ...
- 希尔排序的理解和实现(Java)
希尔排序原理 希尔排序(shell sort)这个排序方法又称为缩小增量排序,是1959年D·L·Shell提出来的. 该方法的基本思想是:设待排序元素序列有n个元素,首先取一个整数increment ...
- (转)MySQL详解--锁
原文:http://blog.csdn.net/xifeijian/article/details/20313977 锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源( ...
- 前端的CRUD增删改查的小例子
前端的CRUD增删改查的小例子 1.效果演示 2.相关代码: <!DOCTYPE html> <html lang="en"> <head> & ...
- Android 7.0 FileProvider 使用说明
FileProvider FileProvider 这个组件在Android 22.0.0 (也就是 Android 5.0 ) 版本下加入进Android系统,该组件是ContentProvider ...
- R语言运算符
运算符是一个符号,它告诉编译器执行特定的数学或逻辑操作. R语言丰富的内置运算符,并提供以下类型的运算符. 运算符类型 在R编程中有以下类型的运算符 - 算术运算符 关系运算符 逻辑运算符 赋值运算符 ...
- R语言常用包分类总结
常用包: ——数据处理:lubridata ,plyr ,reshape2,stringr,formatR,mcmc: ——机器学习:nnet,rpart,tree,party,lars,boost, ...
- 5-niginx-健康检查模块
1, nginx有一个自带的健康检查模块, 过于丑陋... 只需要在 nginx.conf下的http中的server配置如下即可 location /basic_status { stub_sta ...