提供大于 255 的值作为 MySQL CHAR() 函数的参数,MySQL 将返回什么?

MySQL CHAR() 函数

MySQL CHAR() 函数用于返回由 ASCII 值表示的字符。它接受一个或多个整数作为参数,并返回相应的字符。

CHAR(int1, int2, ...);

该函数的参数必须是介于 0 和 255 之间的整数。

大于 255 的值作为 MySQL CHAR() 函数参数

如果我们提供大于 255 的值作为 MySQL CHAR() 函数的参数,会发生什么呢?

我们来试一下:

SELECT CHAR(300);

我们运行上面的 SQL 命令,将 300 作为 CHAR() 函数的参数。MySQL 应该返回一个由 ASCII 300 表示的字符。

但是,当我们运行上面的 SQL 命令时,MySQL 显示了一个警告:

Warning: Truncated incorrect INTEGER value: '300'

这是因为 300 是大于 255 的,不是有效的 ASCII 值。

MySQL 将该值截断为 8 位(即使用模运算符将其除以 256,并将余数作为结果),在本例中应该是 44(300%256=44)。因此返回的字符是由 ASCII 44 表示的逗号。

我们可以通过以下方式来验证这一点:

SELECT CAST(CHAR(300) AS UNSIGNED);

上面的 SQL 命令将字符转换为无符号整数。在本例中,逗号的 ASCII 值是 44。

CHAR() 函数中的负数

如果我们试图在 MySQL CHAR() 函数中使用负数,则会发生什么?

让我们尝试将 -1 作为 CHAR() 函数的参数:

SELECT CHAR(-1);

我们会看到一个错误消息:

ERROR 1305 (42000): FUNCTION test.CHAR does not exist

虽然 MySQL 版本较旧的版本允许使用负数作为 CHAR() 函数的参数,但现在这种情况不再受支持。

结论

MySQL CHAR() 函数要求参数在 0 和 255 之间。如果我们提供大于 255 的值作为函数参数,则会截断该值并返回相应的 ASCII 字符。

在 MySQL CHAR() 函数中不应使用负数。

数据库标签