Background Image

FORUM

조회 수 473 추천 수 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 4443
3767 암호화관련 문의 드립니다. 1 file 초코초코초 2022.12.29 101
3766 모든 테이블의 목록과 각 테이블의 로우 (레코드) 수 확인 4 키롱 2022.12.28 176
3765 큐브리드 FOR문 관련 질의드립니다. 1 계란 2022.12.28 220
3764 [처리완료] 큐브리드 unloaddb, loaddb 시 특수문자 깨짐 및 Lexical error 4 file 백수인 2022.12.27 134
3763 쿼리 튜닝 및 실행계획 관련 문의 드립니다. 3 file kikiki767 2022.12.23 133
3762 펑션 오류 문의드립니다 8 초코초코초 2022.12.17 141
3761 insert 시 오류 문의 1 steve 2022.12.16 127
3760 cubrid11.2 embedded SQL 지원 여부 및 메뉴얼 위치? 1 jjune1206 2022.12.15 45
3759 Error : [-596] The 1953 pages of total temporary space allowed have been exceeded. 2 리들러 2022.12.10 264
3758 큐브리드 DB링크 문의드립니다. 4 file 초코초코초 2022.12.01 150
3757 Oracle to CUBRID Migration 방안 1 DBS 2022.12.01 94
3756 cubrid 엔진 설치 오류 1 file minsung 2022.12.01 72
3755 kill 명령어로 프로세스가 죽지 않을때 3 나라디 2022.12.01 154
3754 특정 컬럼 order by 시 한글 > 숫자 > 영문 순으로 정렬 방법? 2 Qubrid 2022.12.01 427
3753 클라우드 환경에서 데이터베이스 추가 관련 1 디콘플러스 2022.11.29 68
3752 csql로 sql파일 실행 시 변수 전달 3 공도비 2022.11.29 136
3751 Cubrid 이용 관련 문의 - 데이터 손실 1 flash 2022.11.24 172
3750 select 문의 응답속도가 느립니다. 2 steve 2022.11.22 156
3749 큐브리드 검색 초건 총 개수 구하는 함수나 방법알고 싶어요. 1 우유악마 2022.11.22 243
3748 create table 시 응답이 없습니다. 6 steve 2022.11.22 105
Board Pagination Prev 1 ... 7 8 9 10 11 12 13 14 15 16 ... 200 Next
/ 200

Contact Cubrid

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