CHAR_LENGTH() :Return number of characters(字符) in argument(参数)
LENGTH() : Return the length of a string(字符串) in bytes(字节)
https://dev.mysql.com/doc/refman/5.5/en/string-functions
官方说明,CHAR_LENGTH() 返回变量中字符的个数,LENGTH() 返回一个字符串占多少字节。
个人英语比较马虎,所以不知道翻译对不对,凑合看。
结论:
gbk-gbk 一个中文字符也是一个字符,一个汉子占两个字节,所以是 5 7
gbk - utf8 不能直接转换,需通过unicode转码,转码后就是 7 7
gbk- latin1 可直接转换,转换为单字节字符,转码后是 7 7
utf8(一个中文三个字节)---gbk: 直接转换,尾部奇数字节截断(中文个数*3/2+英文字符个数) 9 9
utf8(一个中文三个字节)---utf8: 不用转换,就是 5 9
utf8--------latin1: 直接转换,单字节字符 就是 9 9
select char_length('世界sad'),length('世界sad');的结果跟两个因素有关:
客户端(linux默认utf8,windows默认GB2312,可通过securecrt 模拟),mysql字符编码设置(主要是client,connection和result,set names xxx)
测试1:
mysql version:5.6.17 windows 7 平台
mysql> set names utf8;
Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');
+------------------------+-------------------+
| char_length('世界sad') | length('世界sad') |
+------------------------+-------------------+
| 7 | 7 |
+------------------------+-------------------+1 row in set (0.00 sec)
mysql> show variables like 'char%';
+--------------------------+-----------------------------------------------+
| Variable_name | Value |
+--------------------------+-----------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | D:\wamp\bin\mysql\mysql5.6.17\share\charsets\ |
+--------------------------+-----------------------------------------------+8 rows in set (0.00 sec)
mysql> set names gbk;
Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');
+------------------------+-------------------+
| char_length('世界sad') | length('世界sad') |
+------------------------+-------------------+
| 5 | 7 |
+------------------------+-------------------+1 row in set (0.00 sec)
mysql> set names latin1;
Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');
+------------------------+-------------------+
| char_length('世界sad') | length('世界sad') |
+------------------------+-------------------+
| 7 | 7 |
+------------------------+-------------------+1 row in set (0.00 sec)
测试2:
mysql 5.5 tlinux 1.2/centos 6.x
mysql> set names utf8;Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');+--------------------------+---------------------+| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+| 5 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
mysql> set names gbk;Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');+--------------------------+---------------------+| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+| 6 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
mysql> set names latin1;Query OK, 0 rows affected (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');+--------------------------+---------------------+| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+| 9 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
mysql>
测试3: mysql 5.6 tlinux1.2
elcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1Server version: 5.6.25 Source distribution
Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 5 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
mysql> show variables like 'char%';
+--------------------------+-----------------------------------------+
| Variable_name | Value |
+--------------------------+-----------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql-5.6.25/share/charsets/ |
+--------------------------+-----------------------------------------+8 rows in set (0.00 sec)
mysql> set names gbk;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'char%';
+--------------------------+-----------------------------------------+
| Variable_name | Value |
+--------------------------+-----------------------------------------+
| character_set_client | gbk |
| character_set_connection | gbk |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | gbk |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql-5.6.25/share/charsets/ |
+--------------------------+-----------------------------------------+8 rows in set (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 6 | 9 |
+--------------------------+---------------------+1 row in set (0.02 sec)
mysql> set names latin1;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'char%';
+--------------------------+-----------------------------------------+
| Variable_name | Value |
+--------------------------+-----------------------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql-5.6.25/share/charsets/ |
+--------------------------+-----------------------------------------+8 rows in set (0.00 sec)
mysql> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 9 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
mysql>
测试4:
mariadb 5.5 tlinux 2.0/centos 7
[iyunv@tlinux2_ops01 ~]# rpm -qa |grep mariadbmariadb-devel-5.5.41-2.el7_0.x86_64
mariadb-libs-5.5.41-2.el7_0.x86_64
mariadb-server-5.5.41-2.el7_0.x86_64
mariadb-embedded-devel-5.5.41-2.el7_0.x86_64
mariadb-embedded-5.5.41-2.el7_0.x86_64
mariadb-test-5.5.41-2.el7_0.x86_64
mariadb-5.5.41-2.el7_0.x86_64
mariadb-bench-5.5.41-2.el7_0.x86_64
[iyunv@tlinux2_ops01 ~]# mysqlWelcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 58Server version: 5.5.41-MariaDB-log MariaDB Server
Copyright (c) 2000, 2014, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> show variables like 'char%';show variables like 'char%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+8 rows in set (0.00 sec)
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+8 rows in set (0.00 sec)
MariaDB [(none)]> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 9 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
MariaDB [(none)]> set names gbk;
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 6 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
MariaDB [(none)]> set names utf8;
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> select char_length('世界sad'),length('世界sad');
+--------------------------+---------------------+
| char_length('世界sad') | length('世界sad') |
+--------------------------+---------------------+
| 5 | 9 |
+--------------------------+---------------------+1 row in set (0.00 sec)
MariaDB [(none)]>
测试5:
windows系统(终端设置为utf8) mysql 5.6
chcp 65001
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com