数据库中的字符类型存储字符和汉字的数量
sqlserver2012(936 简体中文gbk )为例:
例如:
varchar(10),只能存储10个英文字符或数字,也只能存储5个汉字;
char(10),只能存储10个英文字符或数字,也只能存储5个汉字;
nvarchar(10),即存储10个英文字符或数字,也能存储10个汉字;
nchar(10),即存储10个英文字符或数字,也能存储10个汉字;
varchar(max),大值数据类型最多可以存储2^30-1个字节的数据(varchar(max)、nvarchar(max)、varbinary(max))
小结:
unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。
而前缀n就表示unicode字符,比如nchar,nvarchar,这两种类型使用了unicode字符集。
超过大小会提示出错。
补充说明:
sql server中的varchar和nvarchar的区别:
1. varchar按实际字节长度存储,1个汉字1字节,1个英文1字节,长度介于1和8000之间,存储大小为输入数据的字节的实际长度
2. nvarchar按字符数量存储,不论汉字或英文,都是2字节,长度介于1与4000之间,存储大小是所输入字符个数的两倍(n前缀的,n表示unicode字符,即所有字符都占两个字节)
3. 从存储方式上,nvarchar是按字符存储的,而 varchar是按字节存储的
4. 从存储量上考虑, varchar比较节省空间,因为存储大小为字节的实际长度,而 nvarchar是双字节存储
5. 如果你做的项目可能涉及不同国家语言之间的转换,建议用nvarchar,因为nvarchar是使用unicode编码,会减少乱码的出现几率
6. char/nchar固定长度数据类型,不足的补英文半角空格。
len()函数:返回给定字符串表达式的字符(而不是字节)个数,其中不包含尾随空格。(len只返回字符数,一个汉字代表一个字符)
datalength()函数:返回任何表达式所占用的字节数。(datalength返回的是字节数,一个汉字两个字节)
len()不包含空格在内长度,而datalength()包含空格。
mysql:
在5.5.49的版本,字符集是utf-8下,char(10)和varchar(10)存储的汉字和英文的数量都是10个
下一篇: Centos 7修改hostname浅析
推荐阅读
-
以php中的比较运算符操作整型,浮点型,字符串型,布尔型和空类型
-
C++中字符串和int\float\char*类型的相互转换
-
数据库中的字符类型存储字符和汉字的数量
-
关于mysql中时间日期类型和字符串类型的选择
-
php-网页中PHP代码向sqlite数据库写数据时,“000...0”这样的字符串会被存储为0,求解原因?
-
注册表中存储数据库链接字符串的方法
-
php-网页中PHP代码向sqlite数据库写数据时,“000...0”这样的字符串会被存储为0,求解原因?
-
以php中的比较运算符操作整型,浮点型,字符串型,布尔型和空类型
-
Java中基本类型和字符串之间的转换
-
Java中基本类型和字符串之间的转换