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 4263
3856 브로커(CAS)수 질문드립니다! 8 요시니 2023.06.05 149
3855 데이터 이관 문의입니다. 1 kipo0821 2023.05.30 125
3854 8.4.4 charset. Collation 확인 방법 네오랜덤 2023.05.24 175
3853 8.4.4버젼 charset 확인 3 네오랜덤 2023.05.23 182
3852 쿼리 속도 차이 질문 1 하얀미스 2023.05.18 139
3851 spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다. 3 kjaminam 2023.05.18 725
3850 cci 프로그래밍에서 DB LINK 관련 문의 4 jjune1206 2023.05.18 123
3849 큐브리드 매니저 실행이 오류 1 file 청주시청 2023.05.18 97
3848 ddl 추출 1 네오랜덤 2023.05.17 95
3847 하나의 쿼리에서 복수 테이블 업데이트 방법 문의 4 도담도담 2023.05.17 123
3846 cubrid driver 설치 문의 1 고구망구망 2023.05.08 425
3845 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다. 1 뿡이 2023.04.28 127
3844 Fk값 가져오기 2 file 네오랜덤 2023.04.24 159
3843 서버 메모리 교체 및 ha 상 데이터 삭제 절차 1 레피엘 2023.04.20 106
3842 java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의 3 개미가불쌍해 2023.04.18 138
3841 Cubrid stored procedure 스케쥴 등록 형식 2 Roy 2023.04.17 104
3840 암호화 함수 MDB_ENC 질문입니다 1 BE-DEV 2023.04.17 79
3839 auto_increment 추가 방법 문의 1 부패방지운영팀 2023.04.14 241
3838 CUBRID 사용자 계정 생성 관련 문의 1 몽키스패너 2023.04.14 127
3837 order by 이후 rownum이 의도와 다르게 찍힙니다. 2 바보똥개 2023.04.14 134
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