다음 오류 메시지를 고려하십시오.
ERROR: function fnupdatesalegtab09(integer, integer, integer, integer, integer, unknown, unknown, integer, unknown, integer, unknown, integer, integer, integer, numeric, integer, integer, unknown, integer, integer, integer, integer, integer, integer, integer, integer, integer, integer, integer, unknown, integer, boolean, unknown, unknown, unknown, unknown, boolean, unknown, unknown, integer, unknown, integer, integer, integer, integer, integer) does not exist LINE 1: select FnUpdateSalegtab09 (4, 1, 0, 12, 1, '9','2014-07-15',... ^ HINT: No function matches the given name and argument types. You might need to add explicit type casts.
이 시나리오에서는 특정 매개변수를 사용하여 FnUpdateSalegtab09라는 함수를 호출하도록 만들어졌습니다. 그러나 오류는 해당 함수가 존재하지 않음을 나타냅니다. 또한 이 오류는 지정된 이름 및 인수 유형과 일치하는 함수가 없음을 나타냅니다.
오류는 캐스팅 문제로 인한 것일 수 있습니다. 함수 호출에서 숫자 리터럴은 함수 정의에서 smallint로 정의된 매개변수에 사용됩니다. 숫자 리터럴은 해당 값이 정수 유형에 맞는 경우 처음에는 정수 유형으로 간주됩니다. 제공된 명시적 유형 캐스트가 없기 때문에 예상 인수 유형과 실제 인수 유형이 일치하지 않을 수 있습니다.
이 문제를 해결하려면 다음의 숫자 리터럴에 명시적 유형 캐스트를 추가하세요. 예상되는 smallint 데이터 유형과 일치하는 함수 호출. 또는 함수 호출에 따옴표(유형이 지정되지 않은) 리터럴을 사용할 수 있습니다.
잘못된 호출:
SELECT * FROM f_typetest(1);
올바름 호출:
SELECT * FROM f_typetest('1'); SELECT * FROM f_typetest(smallint '1'); SELECT * FROM f_typetest(1::int2); SELECT * FROM f_typetest('1'::int2);
이러한 조정을 통해 이제 함수 호출이 오류 없이 인식되고 실행됩니다.
위 내용은 '함수가 존재하지 않습니다' 오류와 함께 SQL 함수 호출이 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!