中文汉字的长度验证
表单验证最麻烦之一是中文汉字的长度验证
目的是验证长度验证
验证方法
1.使用javascript 字符串length属性验证长度
2.使用动态语言(本文用的是c#)length 验证长度
注:但是无论是字母,数字,汉字都当成一个字节单位来存储
eg.string str="中国12" 使用length属性得出结果是4,这是正确。但是如果要将数据插入数据库就麻烦了
varchar一般用于存储比较短字符串,定义长度为4
varchar(4)
定义:string str="长江7号",插入数据库,显示会出现异常
原因:str.length=4
System.Text.Encoding.Default.GetByteCount(str)=7 //计算字节个数
(汉字两个字节存储)
显然varchar(4)是不够存储str.
很多时候一条字符串包含了中英,用varchar显得不好控制长度,使用nvarchar可以解决这问题之一。
nvarchar varchar 区别
nvarchar不论是字母,数字,汉字,符号等都是以二个字符来存储
varchar 汉字二个字节,字母,一个字节,等等,