登录  /  注册

MySQL中CHARACTER_LENGTH()函数的用法详解

藏色散人
发布: 2019-04-25 17:06:09
原创
7834人浏览过

mysql中,character_length()函数返回字符串的长度,以字符为单位。

CHARACTER_LENGTH()是CHAR_LENGTH()函数的同义词。

语法是这样的:

CHARACTER_LENGTH(str)
登录后复制

其中str是返回长度的字符串。

例1 -基本用法

下面是一个基本用法的例子:

SELECT CHARACTER_LENGTH('Cat');
登录后复制

结果是这样的:

+-------------------------+
| CHARACTER_LENGTH('Cat') |
+-------------------------+
|                       3 |
+-------------------------+
登录后复制

例2 -末尾有空格

注意,CHARACTER_LENGTH()在其计算中包含末尾空格(例如字符串末尾的空格)。

所以如果我们在前一个例子的末尾加上空格:

SELECT CHARACTER_LENGTH('Cat ');
登录后复制

结果:

+--------------------------+
| CHARACTER_LENGTH('Cat ') |
+--------------------------+
|                        4 |
+--------------------------+
登录后复制

但是我们可以使用TRIM()函数或RTRIM()函数来删除后面的空格:

SELECT 
  CHARACTER_LENGTH(TRIM('Cat ')) AS 'TRIM',
  CHARACTER_LENGTH(RTRIM('Cat ')) AS 'RTRIM';
登录后复制

结果:

+------+-------+
| TRIM | RTRIM |
+------+-------+
|    3 |     3 |
+------+-------+
登录后复制

例3 -前面有空格

同样的概念也适用于前面空格。你可以使用TRIM或LTRIM:

SELECT 
  CHARACTER_LENGTH(TRIM(' Cat')) AS 'TRIM',
  CHARACTER_LENGTH(LTRIM(' Cat')) AS 'LTRIM';
登录后复制

结果:

+------+-------+
| TRIM | LTRIM |
+------+-------+
|    3 |     3 |
+------+-------+
登录后复制

例4 -数据类型

无论字符串存储为什么数据类型,它都将返回相同的结果。这与LENGTH()函数形成对比,如果数据是以Unicode字符串存储的,那么LENGTH()函数将返回双倍的字符数。

在下面的例子中,ArtistName列使用varchar(255):

SELECT CHARACTER_LENGTH(ArtistName) Result
FROM Artists
WHERE ArtistName = 'Lit';
登录后复制

结果:

+--------+
| Result |
+--------+
|      3 |
+--------+
登录后复制
登录后复制

如果我们修改ArtistName列来使用Unicode:

ALTER TABLE Artists 
MODIFY COLUMN ArtistName VARCHAR(255) unicode;
登录后复制

并再次运行相同的查询:

SELECT CHARACTER_LENGTH(ArtistName) 
FROM Artists
WHERE ArtistName = 'Lit';
登录后复制

我们仍然得到相同的结果:

+--------+
| Result |
+--------+
|      3 |
+--------+
登录后复制
登录后复制

但是,如果使用LENGTH()函数,结果将是6。这是因为Unicode字符串每个字符存储2个字节,LENGTH()函数返回以字节为单位测量的长度。

相关推荐:《mysql教程

以上就是MySQL中CHARACTER_LENGTH()函数的用法详解的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号