设为首页 收藏本站
查看: 351|回复: 0

[经验分享] mysql CHAR_LENGTH()与LENGTH()

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-8-25 08:37:20 | 显示全部楼层 |阅读模式
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)



wKioL1XbRSqieeNHAAXkG2oMkKg105.jpg



测试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
wKiom1XbQxXgg0W5AAbRB17OJDU558.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-103778-1-1.html 上篇帖子: MySQL数据乱码 下篇帖子: mysql授权远程访问
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表