理解错误:“错误:函数...不存在并且提示:没有函数与给定名称和参数类型匹配”
当尝试执行函数时,确保指定的函数名称和参数类型与实际函数定义匹配至关重要。如果不匹配,您可能会遇到错误“错误:函数...不存在,提示:没有函数与给定的名称和参数类型匹配。”
解决方案:检查参数类型
在此特定场景中,错误与函数定义中的“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中文网其他相关文章!