MongoDB聚合运算符:$strLenBytes

MongoDB聚合运算符:$strLenBytes


$strLenBytes聚合运算符返回指定字符串中 UTF-8 编码的字节数。

语法

{
   
    $strLenBytes: <string expression> }

<expression>为可解析为字符串的表达式,如果解析为null或引用了不存在的字段,返回错误。

使用

$strLenBytes运算符计算字符串中 UTF-8 编码字节的数量,字符可以使用1到4个字节。例如,US-ASCII 字符使用一个字节进行编码;带有变音符号的字符和附加拉丁字母字符(即英语字母表之外的拉丁字符)使用两个字节进行编码;中文、日文和韩文字符通常需要三个字节,而其他 unicode 平面(表情符号、数学符号等)则需要四个字节。

$strLenBytes运算符与$strLenCP运算符不同,后者计算指定字符串中的代码点,而不管每个字符使用多少字节。

返回 说明
{ $strLenBytes: "abcde" } 5 每个字符使用一个字节进行编码
{ $strLenBytes: "Hello World!" } 12 每个字符使用一个字节进行编码
{ $strLenBytes: "cafeteria" } 9 每个字符使用一个字节进行编码
{ $strLenBytes: "cafétéria" } 11 é使用两个字节进行编码
{ $strLenBytes: "" } 0 空字符串返回0
{ $strLenBytes: "$€λG" } 7 使用3个字节编码,λ使用2个字节编码
{ $strLenBytes: "寿司" } 6 每个字符使用3个字符

举例

单字节和多字节字符集

使用下面的脚本创建food集合:

db.food.insertMany(
 [
    {
   
    "_id" : 1, "name" 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

原子星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值