首页 >数据库 >mysql教程 >为什么我会收到'错误:函数...不存在”错误以及如何修复函数调用中的类型不匹配?

为什么我会收到'错误:函数...不存在”错误以及如何修复函数调用中的类型不匹配?

DDD
DDD原创
2025-01-05 14:25:40566浏览

Why am I getting the

理解错误:“错误:函数...不存在并且提示:没有函数与给定名称和参数类型匹配”

当尝试执行函数时,确保指定的函数名称和参数类型与实际函数定义匹配至关重要。如果不匹配,您可能会遇到错误“错误:函数...不存在,提示:没有函数与给定的名称和参数类型匹配。”

解决方案:检查参数类型

在此特定场景中,错误与函数定义中的“smallint”参数的类型不匹配有关。但是,在函数调用中,您使用的数字文字被假定为“整数”类型。

理解数字文字

字符串文字(例如'123') 最初是无类型的,并且一直保持这种状态,直到对其值进行赋值或显式转换。但是,如果数字文字(如 123)在允许的范围内,则立即将其键入为“整数”,如果超出该范围,则将立即键入为“bigint”或“数字”。

解决不匹配问题

要解决此问题,您有两个options:

  • 添加显式转换: 在函数调用中为“smallint”参数添加显式转换:

    SELECT FnUpdateSalegtab09 (4, 1, 0, 12, 1, '9'::varchar,'2014-07-15'::timestamp, 4048, '9'::varchar, 4048, 'MYCUSTOMER'::varchar, 12::money, 0, 0::money, 0.32, 185, 0, '2014-07-15 11:24:12 AM'::timestamp, 0, 0::money, 0, 0::money, 0::money, 0, 0::money, 0, 0::money, 0, 0::money, ''::varchar, 0::money, False, ''::varchar, '2014-07-15'::timestamp, ''::varchar, ''::varchar, False, ''::varchar, ''::varchar, 1, ''::varchar, 1,0,1,0,42)
  • 传递非类型化文字:传递引用(非类型化) “smallint”参数的文字:

    SELECT FnUpdateSalegtab09 (4, 1, 0, 12, 1, '9'::varchar,'2014-07-15'::timestamp, 4048, '9'::varchar, 4048, 'MYCUSTOMER'::varchar, 12::money, 0, 0::money, 0.32, 185, 0, '2014-07-15 11:24:12 AM'::timestamp, 0, 0::money, 0, 0::money, 0::money, 0, 0::money, 0, 0::money, 0, 0::money, ''::varchar, 0::money, False, ''::varchar, '2014-07-15'::timestamp, ''::varchar, ''::varchar, False, ''::varchar, ''::varchar, 1, ''::varchar, 1, '0', '1', '0', 42)

以上是为什么我会收到'错误:函数...不存在”错误以及如何修复函数调用中的类型不匹配?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn