[완료] ODBC 프로그래밍 질문입니다.

ljs0766의 이미지

MSSQL 2000을 이용하여 작업을 할 일이 있어서 ODBC를 이용해서 프로그램을 만들었는데
어느정도 DB 연산을 하다보니 HY001 메모리 할당 오류가 발생하더군요.
우선 프로그램이 시작하면 먼저 DB에 연결을 유지한 상태로 작업을 하는데
제 생각은 DB에 연결을 유지한 상태로 계속해서 쿼리를 날리면 안될 듯 합니다.

DB_Connect()->ExecSQL()->DB_Disconnect()

이런 형태로 프로그램이 작성되어야 할 듯 한데
구글링을 해보아도 HY001 메모리 할당 오류에 관한 레퍼런스가
거의 없더군요.

제 생각이 맞는 건지 궁금하군요.

의견 부탁드립니다.

neodeath의 이미지

재 connection 하는 비용은 많이 듭니다.
부하가 상관 없다면 저런 식으로 코딩해도 상관은 없겠구요.

저의 경우
문제가 됐던건 mysql의 경우 time_out때문에
mysql 옵션 설정을 하거나.. ping 을 날려주는 귀찮은 작업으로
connection이 다른 환경에 의해 끊기지 않게 유지를 시켜줬습니다만...

저부분 빼곤 connection 을 유지하고 계속 쿼리를 날려도 문제가 없습니다.

언제 고수되나.

ljs0766의 이미지

ODBC의 옛날버젼 API와 최신버젼(?) API를 혼용해서 썼더니..
메모리가 제대로 해제가 안되서 저런 문제가 생겼더군요;;
DB쪽 프로그래밍은 처음인지라 많이 헷갈리네요 ^^

ssenk의 이미지

욕지행
ODBC어떤 버전이 메모리릭이 있는지 알려주세요...

욕지행

ljs0766의 이미지

SQLAllocHandle( )로 할당한 Statement를
SQLFreeStmt로 해제하려고 했을 경우 해제가 안됩니다.

즉 SQLAllocHandle로 할당한 핸들러들은 SQLFreeHandle로 해제 해주어야 합니다.
기존에 사용하던 SQLFreeStmt와 같은걸로 해제를 시도하면
메모리 해제가 안되고 메모리 누수가 발생하더군요.

ljs0766의 이미지

SQLAllocHandle( )로 할당한 Statement를
SQLFreeStmt로 해제하려고 했을 경우 해제가 안됩니다.

즉 SQLAllocHandle로 할당한 핸들러들은 SQLFreeHandle로 해제 해주어야 합니다.
기존에 사용하던 SQLFreeStmt와 같은걸로 해제를 시도하면
메모리 해제가 안되고 메모리 누수가 발생하더군요.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.