>데이터 베이스 >MySQL 튜토리얼 >데이터를 반환하지 않는 저장 프로시저에서 \'오류 1329: 데이터 없음\'을 억제하는 방법은 무엇입니까?

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

Patricia Arquette
Patricia Arquette원래의
2024-10-26 15:46:30603검색

How to Suppress

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

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

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

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

<code class="sql">READS SQL DATA</code>

이 줄은 프로시저가 테이블에서만 읽을 뿐 어떤 행도 반환하지 않음을 데이터베이스에 알립니다.

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

<code class="sql">DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;</code>

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

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

<code class="sql">SELECT name INTO l_name FROM customer_tbl LIMIT 1;</code>

이러한 접근 방식을 따르면 개발자는 데이터를 반환하지 않는 저장 프로시저에 대한 "오류 1329" 메시지를 억제하여 불필요한 작업 없이 보다 원활한 실행을 보장할 수 있습니다. 오류 메시지가 나타납니다.

위 내용은 데이터를 반환하지 않는 저장 프로시저에서 \'오류 1329: 데이터 없음\'을 억제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.