개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.03.16 15:46

OCI_SET_ACTION 관련 질문

  • 암호화마스터 16시간 전 2025.03.16 15:46 새글
  • 6
    1
안녕하세요 선생님,
오라클 DB에 연결하여 SQL문을 실행할 때, oci_set_action 함수를 사용하여 동작을 지정할 수 있다고 배웠습니다.

하지만, 이 함수를 사용하는 방법에 대해 조금씩 혼동이 생기네요.

해당 함수의 첫 번째 인자는 어떤 역할을 하나요?

그리고, 이 함수를 사용할 때는 어떤 조건이 있어야 하나요?

혹시, 예시 코드를 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  16시간 전



    OCI_SET_ACTION 함수의 첫 번째 인자는 SQL 문에 대한 동작을 지정하는 문자열입니다. 예를 들어, INSERT, UPDATE, DELETE 등 다양한 동작을 지정할 수 있습니다.

    OCI_SET_ACTION 함수를 사용할 때는 SQL 문이 실행되기 전에 호출해야 합니다. 또한, 함수의 두 번째 인자는 SQL 문을 실행할 때 사용할 커서 이름입니다.

    OCI_SET_ACTION 함수의 예시 코드는 다음과 같습니다.

    #hostingforum.kr
    c
    
    #include 
    
    
    
    int main() {
    
        // 오라클 연결 설정
    
        OCIEnv* env;
    
        OCIHandleAlloc(NULL, (dvoid)&env, OCI_HTYPE_ENV, 0, NULL);
    
    
    
        // 오라클 세션 설정
    
        OCISession* sess;
    
        OCIHandleAlloc(env, (dvoid)&sess, OCI_HTYPE_SESSION, 0, NULL);
    
    
    
        // SQL 문 실행
    
        OCIBind* bind;
    
        OCIHandleAlloc(env, (dvoid**)&bind, OCI_HTYPE_BIND, 0, NULL);
    
    
    
        // OCI_SET_ACTION 함수 호출
    
        OCIAttrSet(sess, OCI_HTYPE_SESSION, "INSERT", strlen("INSERT"), 0, env);
    
    
    
        // SQL 문 실행
    
        OCISQLExecute(env, sess, (dvoid*)"INSERT INTO 테이블명 (컬럼명) VALUES ('값')", strlen("INSERT INTO 테이블명 (컬럼명) VALUES ('값')"), 0, NULL, NULL, NULL, NULL, NULL, NULL);
    
    
    
        // 오라클 연결 해제
    
        OCITerminate(env, 0, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
    
    
    
        return 0;
    
    }
    
    


    위 코드는 INSERT 문을 실행할 때 OCI_SET_ACTION 함수를 사용하는 예시입니다. OCI_SET_ACTION 함수를 사용할 때는 SQL 문이 실행되기 전에 호출해야 하며, 함수의 두 번째 인자는 SQL 문을 실행할 때 사용할 커서 이름입니다.

    2025-03-16 15:47

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 4,038건 / 12 페이지

검색

게시물 검색