Background Image

FORUM

2023.04.05 20:47

blob select

조회 수 141 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Linux 64bit
CUBRID Ver
9.2.9.0002
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
1. 테이블 생성후  

<Class Name> 

     test_blob

 <Attributes> 

     bid                  INTEGER
     file_content         BLOB
     file_name            CHARACTER VARYING(10)
 

 

2. 명령어를 실행해서 최종적으로 데이터를 .csv로 뽑아내면서 file_content 컬럼은 경로정보를 얻고자 합니다. 

csql -u dba -p dba demodb@localhost -c "SELECT CONCAT(bid,',',file_content,',',file_name) FROM (select bid,file_content,file_name from test_blob) A"

      -o data.csv

 

3. 하지만 에러가 아래와 같이 나면서 실행이 되지 않습니다.

ERROR: Cannot coerce A.file_content to type varchar.

 

 

blob 타입을 문자열함수로 CONCAT해서 그런거 같은데  blob의 경로를 문자열로 뽑아낼수 있는 방법이 있나요?

 

 

 

 

 

 

  • ?
    원종민 2023.04.06 10:56

    BLOB 타입을 문자열(varchar,char) 타입으로 변환이 불가능 합니다.
    * 온라인 매뉴얼의 "명시적인 타입 변환 정리 표" 참조 : https://www.cubrid.org/manual/ko/9.3.0/sql/function/typecast_fn.html?highlight=cast#id1

     

    따라서, 우회 방법으로 data.csv 파일을 리눅스 sed 명령어로 가공하면 원하는 결과를 추출 할 수 있습니다.

     

    예제) sed 명령어로 가공 방법
    1. 쿼리 수행
    $ csql -u dba demodb -c "select col1, col2, col3 from test02" -o data.csv

     

    2. 원본
    $ cat data.csv

    === <Result of SELECT Command in Line 1> ===

             col1  col2                  col3                
    =========================================================
                1  file:/data/DB/gm_newdb/ces_190/test02.00001680741708877843_1688  'cccddd'            
                2  file:/data/DB/gm_newdb/ces_158/test02.00001680743119123415_1027  'ccc2ddd2'          

    2 rows selected. (0.000493 sec) Committed.

     

    3. data.scv 파일 가공
    $ cat data.csv | sed -n "/file/p" | sed -e "s/'//g" | sed -e "s/^ */'/g" -e "s/ *$/'/g" | sed -e "s/  /,/g" > data_process.csv
    - 1 번 째 파이프 : file 이라는 단어가 포함된 라인 만 출력
    - 2 번 째 파이프 : '(작은 따옴표) 문자가 포함된 단어 제거
    - 3 번 째 파이프 : 모든 문자열의 앞,뒤에 '(작은 따옴표) 문자 추가
    - 4 번 째 파이프 : 모든 문자열의 공백 2개를 ,(쉼표)문자로 변환

     

    4. 가공 결과
    $ cat data_process.csv 
    '1,file:/data/DB/gm_newdb/ces_190/test02.00001680741708877843_1688,cccddd'
    '2,file:/data/DB/gm_newdb/ces_158/test02.00001680743119123415_1027,ccc2ddd2'


  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views104
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4468
    read more
  3. NX_transcation

    Date2023.06.12 Byyoo Views79
    Read More
  4. cubrid cursor.close() 에러 관련질문

    Date2023.06.08 By힘내자화이팅 Views187
    Read More
  5. merge 쿼리 속도개선

    Date2023.06.08 Byleeee Views109
    Read More
  6. 브로커(CAS)수 질문드립니다!

    Date2023.06.05 By요시니 Views152
    Read More
  7. 데이터 이관 문의입니다.

    Date2023.05.30 Bykipo0821 Views131
    Read More
  8. 8.4.4 charset. Collation 확인 방법

    Date2023.05.24 By네오랜덤 Views188
    Read More
  9. 8.4.4버젼 charset 확인

    Date2023.05.23 By네오랜덤 Views193
    Read More
  10. 쿼리 속도 차이 질문

    Date2023.05.18 By하얀미스 Views143
    Read More
  11. spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다.

    Date2023.05.18 Bykjaminam Views792
    Read More
  12. cci 프로그래밍에서 DB LINK 관련 문의

    Date2023.05.18 Byjjune1206 Views131
    Read More
  13. 큐브리드 매니저 실행이 오류

    Date2023.05.18 By청주시청 Views103
    Read More
  14. ddl 추출

    Date2023.05.17 By네오랜덤 Views105
    Read More
  15. 하나의 쿼리에서 복수 테이블 업데이트 방법 문의

    Date2023.05.17 By도담도담 Views138
    Read More
  16. cubrid driver 설치 문의

    Date2023.05.08 By고구망구망 Views438
    Read More
  17. 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다.

    Date2023.04.28 By뿡이 Views128
    Read More
  18. Fk값 가져오기

    Date2023.04.24 By네오랜덤 Views166
    Read More
  19. 서버 메모리 교체 및 ha 상 데이터 삭제 절차

    Date2023.04.20 By레피엘 Views114
    Read More
  20. java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의

    Date2023.04.18 By개미가불쌍해 Views147
    Read More
  21. Cubrid stored procedure 스케쥴 등록 형식

    Date2023.04.17 ByRoy Views112
    Read More
  22. 암호화 함수 MDB_ENC 질문입니다

    Date2023.04.17 ByBE-DEV Views82
    Read More
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales