> 데이터 베이스 > MySQL 튜토리얼 > '함수가 존재하지 않습니다' 오류와 함께 SQL 함수 호출이 실패하는 이유는 무엇입니까?

'함수가 존재하지 않습니다' 오류와 함께 SQL 함수 호출이 실패하는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-27 09:33:11
원래의
266명이 탐색했습니다.

Why Does My SQL Function Call Fail with

오류: 함수가 존재하지 않으며 일치하는 함수를 찾을 수 없습니다

다음 오류 메시지를 고려하십시오.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿