gpt4 book ai didi

mysql - SQL - 选择一个增量值或返回一个常量

转载 作者:行者123 更新时间:2023-11-29 06:28:09 24 4
gpt4 key购买 nike

所以我需要做的是选择列的最大值(并每次将其递增 1),如果该值为空(第一次出现时就是这种情况),我必须返回常量 0(这将是下一次出现的最大值)。

我的目标是做这样的事情:

SELECT (Max(id) + 1) FROM my_table WHERE id IS NOT NULL
UNION
SELECT 0 FROM my_table WHERE id IS NULL

但是这不起作用。我能做什么?

最佳答案

按照您的查询编写方式,它将返回两行。一个用于第一个查询,一个用于联合之后。

如果您只想要一行,您可以只使用 MAX() 函数。如果表为空,则 MAX() 函数返回 null。然后,您可以选择在 select 语句中使用 COALESCE(),它返回第一个非空值。换句话说,这个查询:

SELECT COALESCE(MAX(id) + 1, 0) AS maxID
FROM myTable;

可以解释为:给我表中的最大 ID。如果表为空,则返回 0。

这是一个fiddle一个空表和一个非空表的示例。

关于mysql - SQL - 选择一个增量值或返回一个常量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29630143/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com