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 ...
随机推荐
- Flask从入门到精通之自定义错误界面
如果你在浏览器的地址栏中输入了不可用的路由,那么会显示一个状态码为404 的错误页面.现在这个错误页面太简陋.平庸,而且样式和使用了Bootstrap 的页面不一致. 像常规路由一样,Flask 允许 ...
- 本地数据库导入线上服务器的mongodb中
更改默认端口 sudo vi /etc/mongod.conf 进入conf文件,修改port值为19999保存并退出. 重启mongodb sudo service mongod restart 进 ...
- Linux命令学习与使用2
1.Ctrl+a:跳到命令行首 Ctrl+E: 跳到命令行尾 Ctrl+L:清屏2.切换用户 su - 用户名3.更换yum镜像源 1.进入/etc/yum.repos.d 备份CentOS-Base ...
- Swift 里集合类型协议的关系
  Sequence A type that provides sequential, iterated access to its elements. 是最基础的协议,可以通过迭代来获取它的元素 ...
- 【LeetCode】 617. 合并二叉树
题目 给定两个二叉树,想象当你将它们中的一个覆盖到另一个上时,两个二叉树的一些节点便会重叠. 你需要将他们合并为一个新的二叉树.合并的规则是如果两个节点重叠,那么将他们的值相加作为节点合并后的新值,否 ...
- javascript数据结构与算法--基本排序算法(冒泡、选择、排序)及效率比较
javascript数据结构与算法--基本排序算法(冒泡.选择.排序)及效率比较 一.数组测试平台. javascript数据结构与算法--基本排序(封装基本数组的操作),封装常规数组操作的函数,比如 ...
- Java 并发编程——volatile与synchronized
一.Java并发基础 多线程的优点 资源利用率更好 程序设计在某些情况下更简单 程序响应更快 这一点可能对于做客户端开发的更加清楚,一般的UI操作都需要开启一个子线程去完成某个任务,否者会容易导致客户 ...
- php如何判断字符串是否是字母和数字的组合
转载自百度 /其实判断是否是字母和数字或字母数字的组合还可以用PHP ctype_alnum函数 if(!ctype_alnum($vipurl)){ echo '只能是字母或数字的组合';exit; ...
- vue2.0实现购物车功能
购物车功能是一件比较繁琐的事情,逻辑功能太多,今天就用vue2.0实现一个简单的购物车功能,数据都本地自己写的假数据 功能列表: 1.全选和单选结算 2.减少和增加数量 3.商品的删除 界面搭建以及布 ...
- 删除none 的images报错 image has dependent child images 解决办法
这个错是因为在要删除的images之后创建了该images的父images 方法: docker image inspect --format='{{.RepoTags}} {{.Id}} {{.Pa ...