AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1069084
Accepted
Tim
Tim
Asked: 2021-07-09 22:22:09 +0800 CST2021-07-09 22:22:09 +0800 CST 2021-07-09 22:22:09 +0800 CST

为什么当字段为 NULL 时 MariaDB CHAR_LENGTH 返回 NULL 而不是 0?

  • 772

我正在尝试使用 CHAR_LENGTH 计算表中存储的元数据的总大小,以将每行中相关字段的大小相加,以大致了解结果集的存储大小。

我不想要表中所有数据的大小,只想要一组结果的大小。

但是,表中的某些字段具有 NULL 值,一旦 CHAR_LENGTH 达到其中之一,整个计算就会失败,因为 CHAR_LENGTH 返回 NULL 而不是 0。

例如:

SELECT SUM(row_size) as `total` FROM ( SELECT CHAR_LENGTH(`field1`)+CHAR_LENGTH(`field2`)+CHAR_LENGTH(`field3`)+CHAR_LENGTH(`field4`) as `row_size` FROM `meta_data` WHERE `id` = 1 AND `id2` = 2 ) as tbl1;

对于某些查询,这是可行的,我得到了以字节为单位的大小,但对于任何在结果的任何行中的任何字段上具有 NULL 值的查询,我什么都得不到。

为什么 CHAR_LENGTH 不会为 NULL 值返回 0?

我想下一个最好的事情是取回结果并在代码中迭代它们以增加大小。我希望避免这样做,但这可能是唯一的方法吗?

mysql mariadb
  • 2 2 个回答
  • 86 Views

2 个回答

  • Voted
  1. Best Answer
    Rick James
    2021-07-09T23:04:38+08:002021-07-09T23:04:38+08:00

    用 包围每个COALESCE(..., 0)。

    mysql> SELECT CHAR_LENGTH(null), CHAR_LENGTH(''), CHAR_LENGTH('abc');
    +-------------------+-----------------+--------------------+
    | CHAR_LENGTH(null) | CHAR_LENGTH('') | CHAR_LENGTH('abc') |
    +-------------------+-----------------+--------------------+
    |              NULL |               0 |                  3 |
    +-------------------+-----------------+--------------------+
    
    mysql> SELECT COALESCE(CHAR_LENGTH(null), 0);
    +--------------------------------+
    | COALESCE(CHAR_LENGTH(null), 0) |
    +--------------------------------+
    |                              0 |
    +--------------------------------+
    
    mysql> SELECT LENGTH('????') AS len, CHAR_LENGTH('????') AS char_len;
    +-----+----------+
    | len | char_len |
    +-----+----------+
    |  16 |        4 |
    +-----+----------+
    

    请注意,任何字符串中都有开销——它们之间可能有逗号,可能是换行符,也可能是其他内容。

    此外,CHAR_LENGTH()给出字符数,而不是字节数。

    • 1
  2. Phill W.
    2021-07-10T01:05:48+08:002021-07-10T01:05:48+08:00

    为什么 CHAR_LENGTH 不会为 NULL 值返回 0?

    因为如果传递了一个 NULL 参数,任何函数(显然除了 NVL() 之类的函数)都将返回 NULL。正式地:

    f(NULL) == NULL
    

    更重要的是:

    NULL != '' 
    

    一个空字符串是..好吧..一个空字符串。
    NULL 表示没有数据。

    不是一回事。
    (当然,除非您尝试在 Oracle 数据库中使用 varchar 数据,但即使在 2020 年代,这仍然无法区分)。

    • 0

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve