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 두 번 째 행 이후 값들] + " )"

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4258
896 중복생성 결과로 인한 질문드립니다. 1 ssamdib 2017.04.03 9665
895 증분백업 복구가 잘 않되고 있습니다. 3 reerror 2011.11.08 11507
894 증분백업이 안됩니다. 15 file Philip Park 2020.11.19 270
893 증분백업이 안됩니다. 3 file Philip Park 2020.11.19 101
892 지난번에 이어서 호스트 접속 안되는 문제.. 4 file 미드소나 2013.01.16 7566
891 지원하는 INDEX 종류를 알고 싶습니다. 1 장두 2017.07.19 293
890 질문드려요 2 깔라 2011.04.29 8602
889 질문드립니다. 2 secret centosm 2016.01.11 13
888 질문드립니다. 8 secret 오명일 2017.03.14 21
887 질문드립니다.. 1 dgehrs 2012.04.11 8202
886 질문이 있습니다. 4 bjosbkjx 2019.03.14 378
885 질문이 있어 문의드립니다. 1 키위 2015.03.02 5244
884 질문이라고 할 수 있을려나.. 1 지니보이 2010.12.03 7367
883 질문이요!!!!!! Request timed out 5 쩡훈 2020.07.21 694
882 질문입니다. 1 세스카 2012.02.22 7109
881 질의 결과창에서 편집 기능을 이용하여 행 삭제시 삭제가 되지 않습니다. 3 Spooky 2012.10.12 6539
880 질의 수행 계획 캐시 확인을 어떻게 하는지요 ? 6 성성 2022.01.07 210
879 질의 자동화 관련 문의 드립니다. 3 종이 2013.02.21 6675
878 질의 자동화 실행 오류 4 hoops11 2011.10.26 8121
877 질의 자동화 실행 주기 관련 문의 1 종이 2016.02.11 5953
Board Pagination Prev 1 ... 150 151 152 153 154 155 156 157 158 159 ... 199 Next
/ 199

Contact Cubrid

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