MySQL中character的意思_MySQL中CHARACTER_LENGTH()函数的用法详解

在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()函数来删除后面的空格:SELECTCHARACTER_LENGTH(TRIM('Cat ')) AS 'TRIM',CHARACTER_LENGTH(RTRIM('Cat ')) AS 'RTRIM';结果:+------+-------+| TRIM | RTRIM |+------+-------+|3 |3 |+------+-------+例3 -前面有空格

同样的概念也适用于前面空格。你可以使用TRIM或LTRIM:SELECTCHARACTER_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) ResultFROM ArtistsWHERE ArtistName = 'Lit';结果:+--------+| Result |+--------+|3 |+--------+如果我们修改ArtistName列来使用Unicode:ALTER TABLE Artists MODIFY COLUMN ArtistName VARCHAR(255) unicode;并再次运行相同的查询:SELECT CHARACTER_LENGTH(ArtistName) FROM ArtistsWHERE ArtistName = 'Lit';我们仍然得到相同的结果:+--------+| Result |+--------+|3 |+--------+但是,如果使用LENGTH()函数,结果将是6。这是因为Unicode字符串每个字符存储2个字节,LENGTH()函数返回以字节为单位测量的长度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值