Mysql如何查字段的长度,Mysql中length()、char_length()的区别
1、今天发⽣了⼀件有意思的事情,传输的数据⼤于标准定的字段长度了,我把字段长度调⼤了,把数据传输过来了。谁知道,⼈家的数据不符合标准,要删除了重新搞,那么你如何将超长的数据删除呢,或者将超长的数据查询出来。
  答:剧透⼀下,其实使⽤char_length()查询出来的,就可以把这些删除掉,然后将调⼤的字段长度调⼩就⾏了。备注,我实际操作的字段都是中⽂字符哈,别再写教程写出⾎案了。
2、先了解⼀下,Mysql中length()、char_length()的区别。
字符串长度的正确表示
  1)、length():mysql⾥⾯的length()函数是⼀个⽤来获取字符串长度的内置函数。
  2)、char_length():在mysql内置函数⾥⾯查看字符串长度的还有⼀个函数是char_length()。
  3)、这两个函数的区别是:
    a)、length():单位是字节,utf8编码下,⼀个汉字三个字节,⼀个数字或字母⼀个字节。gbk编码下,⼀个汉字两个字节,⼀个数字或字母⼀个字节。
    b)、char_length():单位为字符,不管汉字还是数字或者是字母都算是⼀个字符。
3、扩展⼀下,MySQL5.0.3版本之后varchar类型的变化。
  1)、MySQL 5.0.3 之前:0--255字节,如:varchar(20)中的20表⽰字节数,如果存放utf-8编码的话只能放6个汉字。varchar(n),这⾥的n表⽰字节数。    MySQL 5.0.3 之后:0--65535字节,varchar(20)表⽰字符数,不管什么编码,既汉字也能放20个。但最多占65532字节(两个字节存放长度,⼩于255字节⽤1个字节存放长度),varchar(n)这⾥的n表⽰字符数,⽐如varchar(200),不管是英⽂还是中⽂都可以存放200个。其他具体区别,可⾃⾏⽹上查询。
4、length()<>char_length(),可以⽤来检验是否含有中⽂字符。
utf-8编码中判定某个字段为全英⽂,length(字段) = char_length(字段)即可。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。