"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 데이터를 반환하지 않는 저장 프로시저에서 \"오류 1329: 데이터 없음\"을 억제하는 방법은 무엇입니까?

데이터를 반환하지 않는 저장 프로시저에서 \"오류 1329: 데이터 없음\"을 억제하는 방법은 무엇입니까?

2024-11-02에 게시됨
검색:576

How to Suppress \

"오류 1329: 데이터 없음" 딜레마 극복

많은 개발자는 다음과 같은 경우 "오류 1329: 데이터 없음 - 행을 가져오거나 선택하거나 처리하지 않음"이라는 실망스러운 문제에 직면합니다. 저장 프로시저를 실행합니다. 그러나 이 오류는 프로시저가 올바르게 작동하는 경우에도 종종 발생하므로 이 불필요한 메시지를 억제하는 방법에 대한 의문이 제기됩니다.

한 가지 잠재적인 해결책은 저장 프로시저 자체에 있습니다. 기본적으로 저장 프로시저는 결과 집합을 반환할 것으로 예상됩니다. 그러나 프로시저가 데이터를 생성하지 않는 작업(예: 데이터 조작 또는 레코드 업데이트)을 수행하는 경우 오류 메시지가 트리거됩니다.

이 문제를 해결하려면 다음을 명시적으로 나타내도록 저장 프로시저를 수정하면 됩니다. 어떤 데이터도 반환하지 않습니다. 이는 프로시저 시작 부분에 다음 행을 추가하여 수행할 수 있습니다.

READS SQL DATA

이 행은 프로시저가 테이블에서만 읽을 것이며 테이블에서만 읽을 것임을 데이터베이스에 알립니다. 모든 행을 반환합니다.

또 다른 접근 방식은 프로시저 내에서 NOT FOUND 예외를 처리하는 것입니다. 커서를 사용하여 테이블에서 행을 가져오는 경우 더 이상 가져올 행이 없는 시나리오가 발생할 수 있습니다. 이로 인해 커서에서 NOT FOUND 예외가 발생합니다. 이 예외를 트래핑하고 플래그를 설정하면 오류 메시지를 피할 수 있습니다.

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

이 줄을 추가하면 커서가 NOT FOUND 예외를 발견할 때 데이터베이스에서 완료 플래그를 1로 설정합니다. 그런 다음 이 플래그를 사용하여 커서 루프를 종료하고 오류 메시지를 트리거하지 않고 프로시저를 완료할 수 있습니다.

마지막으로 또 다른 해결 방법은 테이블에서 읽고 성공하는 추가 더미 쿼리를 실행하는 것입니다. 이렇게 하면 MySQL 5.5.13에서 경고가 지워집니다.

SELECT name INTO l_name FROM customer_tbl LIMIT 1;

이러한 접근 방식을 따르면 개발자는 "오류 1329" 메시지를 표시하지 않을 수 있습니다. 데이터를 반환하지 않는 저장 프로시저를 사용하여 불필요한 오류 메시지 없이 보다 원활한 실행을 보장합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3