本文摘自PHP中文网,作者藏色散人,侵删。
在MySQL中,CHARACTER_LENGTH()函数返回字符串的长度,以字符为单位。CHARACTER_LENGTH()是CHAR_LENGTH()函数的同义词。
语法是这样的:
其中str是返回长度的字符串。
例1 -基本用法
下面是一个基本用法的例子:
1 | SELECT CHARACTER_LENGTH( 'Cat' );
|
结果是这样的:
1 2 3 4 5 | +-------------------------+
| CHARACTER_LENGTH( 'Cat' ) |
+-------------------------+
| 3 |
+-------------------------+
|
例2 -末尾有空格
注意,CHARACTER_LENGTH()在其计算中包含末尾空格(例如字符串末尾的空格)。
所以如果我们在前一个例子的末尾加上空格:
1 | SELECT CHARACTER_LENGTH( 'Cat ' );
|
结果:
1 2 3 4 5 | +--------------------------+
| CHARACTER_LENGTH( 'Cat ' ) |
+--------------------------+
| 4 |
+--------------------------+
|
但是我们可以使用TRIM()函数或RTRIM()函数来删除后面的空格:
1 2 3 | SELECT
CHARACTER_LENGTH(TRIM( 'Cat ' )) AS 'TRIM' ,
CHARACTER_LENGTH(RTRIM( 'Cat ' )) AS 'RTRIM' ;
|
结果:
1 2 3 4 5 | +------+-------+
| TRIM | RTRIM |
+------+-------+
| 3 | 3 |
+------+-------+
|
例3 -前面有空格
同样的概念也适用于前面空格。你可以使用TRIM或LTRIM:
1 2 3 | SELECT
CHARACTER_LENGTH(TRIM( ' Cat' )) AS 'TRIM' ,
CHARACTER_LENGTH(LTRIM( ' Cat' )) AS 'LTRIM' ;
|
结果:
1 2 3 4 5 | +------+-------+
| TRIM | LTRIM |
+------+-------+
| 3 | 3 |
+------+-------+
|
例4 -数据类型
无论字符串存储为什么数据类型,它都将返回相同的结果。这与LENGTH()函数形成对比,如果数据是以Unicode字符串存储的,那么LENGTH()函数将返回双倍的字符数。
在下面的例子中,ArtistName列使用varchar(255):
1 2 3 | SELECT CHARACTER_LENGTH(ArtistName) Result
FROM Artists
WHERE ArtistName = 'Lit' ;
|
结果:
1 2 3 4 5 | +--------+
| Result |
+--------+
| 3 |
+--------+
|
如果我们修改ArtistName列来使用Unicode:
1 2 | ALTER TABLE Artists
MODIFY COLUMN ArtistName VARCHAR(255) unicode;
|
并再次运行相同的查询:
1 2 3 | SELECT CHARACTER_LENGTH(ArtistName)
FROM Artists
WHERE ArtistName = 'Lit' ;
|
我们仍然得到相同的结果:
1 2 3 4 5 | +--------+
| Result |
+--------+
| 3 |
+--------+
|
但是,如果使用LENGTH()函数,结果将是6。这是因为Unicode字符串每个字符存储2个字节,LENGTH()函数返回以字节为单位测量的长度。
相关推荐:《mysql教程》
以上就是MySQL中CHARACTER_LENGTH()函数的用法详解的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql更改用户密码命令有哪些
mysql中什么是聚簇索引
mysql索引是自动使用的么
在linux系统上构建mysql服务器
mysql中唯一索引的关键字是什么
从零开始搭建mysql mmm架构
mysql一共有多少种存储引擎?
mysql如何给表设置组合主键?
mysql中如何获取当前日期?日期函数有哪些?
如何使用“navicat for mysql”
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » MySQL中CHARACTER_LENGTH()函数的用法详解