개발자 Q&A

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

2025.07.17 14:06

OCILob::rewind 관련 질문

목록
  • 보안전문가 3일 전 2025.07.17 14:06
  • 22
    1
제가 OCILob::rewind를 사용하여 BLOB 데이터를 처리하다가 발생하는 오류에 대해 도움을 부탁드립니다.

제가 사용한 코드는 다음과 같습니다.
perl

use DBI;



my $db_handle = DBI->connect("DBI:Oracle:localhost/orcl", "아이디", "비밀번호");

my $sth = $db_handle->prepare("SELECT blob_data FROM 테이블");



$sth->execute();



while (my $row = $sth->fetchrow_arrayref) {

    my $blob = $sth->{NAME}_LOB($row->[0]);

    $blob->bind_columns($blob_data);



    # 오류가 발생하는 부분

    $blob->rewind();

    my $data = $blob->read(1024);

}



이 코드에서 $blob->rewind() 부분에서 오류가 발생합니다. 오류 메시지는 다음과 같습니다.


ORA-22275: 로그인한 사용자가 BLOB에 액세스할 수 없습니다



이 오류를 해결하려면 어떻게 해야 하나요?

제가 사용하는 Oracle 버전은 12c입니다.

해결 방법을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  3일 전



    ORA-22275 오류는 Oracle에서 BLOB에 대한 액세스 권한이 부여되지 않았을 때 발생하는 오류입니다.

    해결 방법은 두 가지가 있습니다.

    1. BLOB에 대한 액세스 권한 부여: Oracle DBA가 BLOB에 대한 액세스 권한을 부여해야 합니다.

    #hostingforum.kr
    sql
    
    GRANT SELECT ON 테이블 TO 아이디;
    
    


    2. LOB을 bind할 때 ROWID를 사용: ROWID를 사용하여 LOB을 bind하면 액세스 권한이 필요하지 않습니다.

    #hostingforum.kr
    perl
    
    my $rowid = $sth->{NAME}_ROWID($row->[0]);
    
    my $blob = $db_handle->lob_fetch($rowid, 1);
    
    


    이러한 방법 중 하나를 적용하면 ORA-22275 오류가 해결됩니다.

    2025-07-17 14:07

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

검색

게시물 검색