MySQL Error number: MY-010147; Symbol: ER_EXCESS_ARGUMENTS; SQLSTATE: HY000

文档解释

Error number: MY-010147; Symbol: ER_EXCESS_ARGUMENTS; SQLSTATE: HY000

Message: Too many arguments (first extra is ‘%s’).

错误说明:

MY-010147错误代码ER_EXCESS_ARGUMENTS。在MySQL中,这个错误表明提供给内置函数的参数数量超过了该函数所允许的最大参数数量。参数的数量通常取决于要执行的函数,这个具体的请求不会生效。

常见案例

这个错误最常见的情况是在调用MySQL内置函数时提供的参数数量超过了该函数所允许的最大参数数量。下面是一个实际的例子,这是一个用户会收到该错误消息的SQL查询:

SELECT CONCAT(‘MySQL’, ‘ Tutorial’, ‘for Beginners’)

在上面的查询中,CONCAT函数期望至少两个参数,但提供了三个参数,因此将出现错误:”ER_EXCESS_ARGUMENTS:CONCAT函数接受最多2个参数,给了3个参数”。

解决方法:

如果收到了ER_EXCESS_ARGUMENTS错误,用户需要考虑下面几点:

• 确认MySQL内置函数的正确使用方法,确保提供的参数个数符合该函数的最大参数数量。

• 调整MySQL内置函数参数的顺序,确保提供的参数个数符合该函数的最大参数数量。

• 考虑不需要提供额外参数的情况以外的可能性。例如,运行以下查询:SELECT CONCAT(‘MySQL’),其中的第二个参数将被认为是null,将不会引发ER_EXCESS_ARGUMENTS错误。

• 检查SQL查询中涉及的内置函数将是否有任何字段出错(通过检查基本拼写错误)。

• 进行其他错误排除,即检查所提供的参数是否是字符串,而不是数字或其他数据类型。

你可能感兴趣的