暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

php中文网最新课程 2019-04-26
827

点击蓝字关注我们!每天获取最新的编程小知识!

源  php中文网      源  www.php.cn


在MySQL中,CHARACTER_LENGTH()函数返回字符串的长度,以字符为单位。

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

语法是这样的:

1

CHARACTER_LENGTH(str)

其中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()函数返回以字节为单位测量的长度。

-END-

声明:本文选自「 php中文网 」,搜索「 phpcnnew 」即可关注!


请点击下方:“阅读原文”,在线查看全部文章内容!

文章转载自php中文网最新课程,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论