ASP로 MySQL을 사용하고 있었습니다. 디비연결해서 쿼리실행하고 결과값 받아서 사용하는 웹에서는 아주 일반적인 작업이지요. 그런데 Stored Procedure를 사용하려고 하는데 문제가 생겼습니다. 디비연결은 ODBC를 사용하고 있었습니다.
"PROCEDURE PROCEDURENAME can't return a result set in the given context"라는 오류메시지입니다. result set을 사용할 수 없더니 이리저리 해봐도 해결책을 찾을 수 없었습니다. 해당 오류메시지에 대해서는 MySQL 메뉴얼에 언급이 있었지만 이리저리 찾아본 결과 PHP나 C에 해당하는 내용인것 같았습니다. 스토어드 프로시져는 크게 이렇다할 게 없는 SELECT쿼리로 결과값 받아오는 정도였습니다.
쓰고있는 라이브러리쪽 문제인가 해서 라이브러리를 완전히 걷어내고 ASP에서 직접 디비 붙어서 수행해 보아도 결과는 마찬가지였습니다. 일반적인 SELECT쿼리를 사용했을때는 괜찮았는데 Stored Procedure를 사용하면 위의 에러메시지가 나타났습니다. MySQL은 5.0.27 Community 버전이었습니다.
Stored Procedure가 문제인지 ODBC가 문제인지 의심하고 있었는데 범인은 ODBC였습니다. 정확히 어떤부분의 동작때문인지까지는 파악하지 못했지만 MySQL ODBC 3.51 Driver를 사용하고 있었는데 버전이 맞지 않아서 지원이 제대로 되지 않은 것입니다. ODBC를 5.1.5버전으로 업그래이드하니까 문제는 바로 해결되었습니다.
ODBC 5.1버전은 MySQL사이트에서 다운로드 받을 수 있습니다. 윈도우에 경우 다운로드 받은 후 인스톨러로 설정하면 [제어판] - [관리도구] - [데이터 원본 (ODBC)] 에서 드라이버탭에 가면
1 2 | Set conn = Server.CreateObject("ADODB.Connection") conn.Open("DRIVER=MySQL ODBC 5.1 Driver;SERVER=서버아이피;DATABASE=디비이름;UID=사용자이름;PWD=비밀번호;") |
커넥션 연결 드라이버를 위 코드처럼 MYODBC방식으로 MySQL 5.1 ODBC Driver를 이용해서 하면 됩니다.
My Comment..
이 글은 엄연히 구분하자면, ASP 관련 글이라고 볼 수 있다..
앞서 200번째 글에서도 언급을 했지만, 내가 접하지 않은 부분들에 대한 글을..
구태여 갖고 오지 않기로 마음 먹었다.. 그와 동시에.. 접하지 않았다 할지라도..
특정 부분에 도움이 된다면, 현존하는 카테고리에 녹아들도록 하기로 했었다..
그런 관점에서 해당 글을 가져왔다.. 비록 ASP 와 관련된 MySQL 이지만..
언어를 떠나서.. 이 글과 같은 DB 연결 도중 에러는 빈번하게 발생할 수 있기 때문이다..
그래서 카테고리도 [DB] 라고 표시했다..
댓글 없음:
댓글 쓰기