Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
window10 64bit
CUBRID Ver.
10.2
CUBRID TOOL Ver.
Manager 10.2
응용 환경(API)
python

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
현재 자동화 시스템을 구축하고 있습니다. 다운로드 받은 데이터 excel을 csv로 변환하여 디비로 연동하려 합니다. 


1. 테이블 명 한글

현재 테이블 명을 한글로 받아야해서 09년도 Q&A에 있는대로 cubrid.conf 파일에 intl_mbs_support=yes를 추가하여 

서버재시작을 하였으나 한글로 되질 않습니다. 질의편집기 상에서도 테스트 해봤구요. 도움이 필요합니다..


2. python에서 작업을 하고있어서 예시로

test[3]='abcd'

if(not cur.execute("SELECT 1 FROM db_class WHERE class_name = 'tablename' ")):         #test[i] 로..

    cur.execute("CREATE TABLE "+test[3])

else: ~~~업데이트부분(alter/update)


만들어야 할 table이 300개정도 되서 리스트로 접근하려하는데 테이블 존재확인하는 쿼리에는 tablename이 ' ' 안에 들어가서 리스트로 접근하기가 어렵더라구요

다른 쿼리나 방법이 있을까요?


3. 테이블을 생성한 후 csv파일을 (행단위로) 읽어서 insert해주면 되는건가요?

cur.execute("INSERT INTO tablename(id,date,.....) VALUES ( 이 부분을 어떻게 지정해줘야할지 몰라서요)


추가로, csv의 첫 행을 컬럼으로 설정하는 방법이 있을까요? 가져오기 기능에서 말고 python으로 할때요!

  • ?
    원종민 2020.02.20 17:19
    안녕하세요 질문해 주신 3가지 답변 드리겠습니다.

    1. 테이블 명 한글
    우선, 한글로 테이블 생성이 가능하며 만약 python 실행 시 "Non-ASCII character '\xed' in file [실행 python 파일]" 에러가 나올 경우, python 코드에 한글을 읽을 수 있도록 상단에 #_*_ coding: utf8 _*_ 명시해 주시면 됩니다.

    그리고

    cubrid.conf의 intl_mbs_support 파라미터 옵션은 CUBRID 9.0 릴리스 노트에 다음과 같이 명시되어 있습니다.

    "문자 셋이 유효한지에 대한 검사 여부를 설정하는 파라미터인 intl_check_input_string이 추가되었다. 이와 함께 single_byte_compare, intl_mbs_support 파라미터는 더 이상 사용되지 않게 되었다."

    (매뉴얼 참조 : https://www.cubrid.org/manual/ko/9.3.0/release_note/r90.html?highlight=intl_mbs_support#cubridsus-7629 )

    2. python에서 작업 진행 예시 코드
    예시로 알려주신 코드 부분에서, 문자열을 수동으로 입력한 코드, 변수로 입력한 코드 두 가지 방법을 소개해 드리겠습니다.

    <기존 코드>
    test[3]='abcd'

    if(not cur.execute("SELECT 1 FROM db_class WHERE class_name = " + 'tablename')):
    cur.execute("CREATE TABLE " + test[0])

    <문자열을 수동으로 입력한 코드 - "한글"이라는 테이블이 없으면 "한글" 테이블 생성 (칼럼은 임의로 작성했습니다.)>
    test=["한글", "문자" ...] # 기존 test[3]='abcd' 리스트 변수의 값을 임의로 변경했습니다.

    if(not cur.execute("select 1 from db_class where class_name = '한글'")):
    cur.execute("CREATE TABLE " + test[0] + "(col1 int primary key, col2 varchar(10) .... )")

    <문자열을 변수로 입력한 코드 - "한글"이라는 테이블이 없으면 "한글" 테이블 생성 (칼럼은 임의로 작성했습니다.)>
    test=["한글", "문자" ...] # 기존 test[3]='abcd' 리스트 변수의 값을 임의로 변경했습니다.

    if(not cur.execute("select 1 from db_class where class_name = " + "'" + test[0] + "'")):
    cur.execute("CREATE TABLE " + test[0] + "(col1 int primary key, col2 varchar(10) .... )")

    3. 테이블을 생성한 후 CSV 파일을 (행단 위로) 읽어서 insert 해주면 되는 건가요?
    해당 부분은 코드로 풀어서 해결할 수 있을 것 같습니다.

    * 우선, CSV를 읽어올 때 반복문을 사용한다는 가정으로 설명했습니다.
    1) CSV 첫 행을 a(임의의 변수)라는 변수에 넣어 준다.

    2) a(임의의 변수)라는 변수를 컬럼 입력하는 부분에 넣어 주고, CSV 두 번 째 행부터 values() 안에 값을 넣어준다.

    ex) cur.execute("INSERT INTO [tablename](" + [a] + ")" + "VALUES( " + [CSV 두 번 째 행 이후 값들] + " )"

  1. SQLGate for CUBRID 영구 무료 라이선스 제공

  2. 브로커(CAS)수 질문드립니다!

  3. 데이터 이관 문의입니다.

  4. No Image 24May
    by 네오랜덤
    2023/05/24 by 네오랜덤
    Views 175 

    8.4.4 charset. Collation 확인 방법

  5. 8.4.4버젼 charset 확인

  6. 쿼리 속도 차이 질문

  7. spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다.

  8. cci 프로그래밍에서 DB LINK 관련 문의

  9. 큐브리드 매니저 실행이 오류

  10. ddl 추출

  11. 하나의 쿼리에서 복수 테이블 업데이트 방법 문의

  12. cubrid driver 설치 문의

  13. 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다.

  14. Fk값 가져오기

  15. 서버 메모리 교체 및 ha 상 데이터 삭제 절차

  16. java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의

  17. Cubrid stored procedure 스케쥴 등록 형식

  18. 암호화 함수 MDB_ENC 질문입니다

  19. No Image 14Apr
    by 부패방지운영팀
    2023/04/14 by 부패방지운영팀
    Views 239  Replies 1

    auto_increment 추가 방법 문의

  20. CUBRID 사용자 계정 생성 관련 문의

  21. order by 이후 rownum이 의도와 다르게 찍힙니다.

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 199 Next
/ 199

Contact Cubrid

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