Background Image

FORUM

조회 수 15693 추천 수 0 댓글 5
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
리눅스에서 대량의 데이터를 큐브리드 DB로 넣으려는 작업을 하고 있습니다.

쉘 스크립트로 자동화 시키려고 하는데요 

$CSQL = csql

$DBNAME = demodb

$CSQL -c "CREATE TABLE ex_table(
  no INT,
  name VARCHAR(1024),
  dep VARCHAR(1024),
  INDEX (name),
  INDEX (dep)
)" $DBNAME

이 구문에서

Unable to access system message catalog.
(null)

이런 에러메시지가 출력이 됩니다.

그냥 명령입력창에서 # csql -c "create 뭐뭐뭐" demodb하면 잘 되는데 말이죠

더불어 인덱스 거는 법도 궁금합니다.

고수님들의 조언 기다리겠습니다.
  • ?
    janus 2009.05.14 04:22
    안녕하세요.!!

    create table문에 unique index, PK, FK이외에는 인덱스를 넣을 수 없습니다.
    아래와 같이 인덱스 생성문을 추가해야 합니다.
    CREATE index idx_name_ex_table on ex_table(name);
    CREATE index idx_dep_ex_table on ex_table(dep);
    인덱스생성 관련 사항은 메뉴얼에 create로 검색하시면 쉽게 찾으실 수 있고,
    대량의 데이터입력을 하신다면 인덱스생성을 나중에 하는 것이 성능에 좋습니다.
    5,000이나 10,000건 단위로 commit주기를 주시는 것이 좋고 CUBRID파라미터 group_commit_interval_in_msecs를 설정하는 것이 좋습니다.

     
  • ?
    공기청정기 2009.05.14 19:36
    친절하고 자세한 답변 감사드립니다. :)

    허나 본문에 적은 인덱스 구문 빼고 단순히 속성만 있는 구문도 sh파일에 넣어서 실행시키니 같은 에러 메시지가 출력되네요 ㅠ_ㅠ
    Unable to access system message catalog.
    (null)

    서...설마 문법오류...는 아니겠죠;
  • ?
    남재우 2009.05.14 20:42
    안녕하세요. 제가 간단히 테스트 해보니 동일한 에러가 발생하지는 않습니다. 제가 테스트한 버젼은 1.4인데요. 버젼확인좀 부탁드립니다. 그리고 no는 예약어라 "로 감싸주셔야 합니다.
    csql -c "create table ex_table ( "no" INT, name varchar(1024), dep varchar(1024) )" <데이터베이스이름>
    처럼 하셔야 합니다...
  • ?
    공기청정기 2009.05.15 02:49
    다른 업무때문에 댓글 확인이 늦었네요. 저도 1.4로 확인되는데요...
    $ cubrid --version
    cubrid (cubrid 유틸리티) R1.4
    Copyright (C) 2008 Search Solution Corporation. All rights reserved by Search Solution.

    남재우님께서 말씀하신데로 콘솔에서 하면 테이블이 생성되든지, 이미 있으면 있다고 얘기가 나오는데요...

    혹시 sh에서 테이블 명이나 DB명을 변수로 인식하도록 했거든요
    예를 들면 a.sh 안에는
    $DBNAME = demodb
    $tblname = ex_table
    $CSQL = home1/usr/local/CUBRID

    로 변수가 지정되어 있고

    $CSQL -c "CREATE TABLE $tblname (number INT, name VARCHAR(1024),..)" $DBNAME 로 실행하도록 하였습니다.....
    ------------

    변수를 사용하지 않고 직접

    csql -c "CREATE TABLE ex_table (number INT, name VARCHAR(1024),..)" testdb 로 작성한 후

    a.sh를 실행시켜도 같은 문제내요... 물론 같은 명령어를 리눅스 명령어로 직접 입력하면 잘 되는데요..ㅠ_ㅠ

    ----

    앗, 혼자 노는것 같은대요,,

    사실 그 명령엉가 다른 작업들과 함께 있는 건데 저 명령어만 따로 a.sh로 만들어서 하니 잘 됩니다.

    다른 작업들과 함께 이뤄지다가 문제가 생긴것 같은아 보이는데요 조금 더 노력(?) 해 보겠습니다.

    감사합니다.
  • ?
    공기청정기 2009.05.15 03:15
    해당 쿼리문이 함수 안에 있는데요 그것이 의심 스러워 a.sh에 (이 쿼리만 동작하게 하도록)함수 안에 넣고 함수를 불러보는 것과 따로 하는것도 해 보았는데요 모두 잘 됩니다......
    결국 제가 기존에 하려던 작업과 이 쿼리문이 함께 있으면 이런 문제가 생긴다는... 걸로 해석되는데요..ㅠ_ㅠ
    가여운 이 초보를 어쩌면 좋을까요 ㅠ_ㅠ 도저히 이해가 되지 않습니다.ㅠ_ㅠ

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 119
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4475
1160 오류번호 -677 3 bchlim 2020.08.11 357
1159 Windows 10 에서 CUBRIDManager-10.1.0.0005-windows-x64와 CUBRID-Windows-x64-10.1-latest 설치후 매니저 실행하고 연결이름을 test 입력시 연결오류발생 2 file simon 2019.01.03 356
1158 서버내 cubrid_statdump_0000.dmp 파일 생성 문제 3 NOS 2020.06.16 356
1157 PHP-Cubrid 연동 오류 (Error: CCI, -16, Cannot connect to CUBRID CAS) 5 cubrid1234 2020.08.10 355
1156 큐브리드 보안과 관련한 기능 문의 드립니다. 1 용이지 2017.07.14 355
1155 CUBRID TDE 관련 질문 3 디비디비딥 2018.08.30 352
1154 JDBC PreparedStatement excute()에서 오류 발생 3 steve 2022.07.18 352
1153 데이터베이스 공간 정리(compactdb) 실행중 정지가능한가요? 1 배추 2018.09.11 351
1152 cubrid manager 설치문의 1 power 2018.11.05 350
1151 JDBC에서 UPDATE, MERGE 속도가 느립니다. 1 file 취우다 2022.03.21 350
1150 Mac OS CUBRID 매니저 Remote host closed connection during handshake 오류 1 오충 2020.05.04 349
1149 실행 오류 : -1016 문의드립니다. 4 동건 2019.05.23 348
1148 Cubrid 9.3 > 10.1 업그레이드 문의 1 술먹지마라 2018.09.11 348
1147 큐브리드 파일 읽기 쓰기 문의 1 임소식 2024.01.18 348
1146 예전에 큐브리드 ERWIN 연동 글을 보고 문의남깁니다. 1 변상민 2020.04.06 348
1145 COUNT 함수 1 file 현수 2020.05.06 348
1144 DB연계과정에서 에러코드 발생되어 문의 드립니다. 1 file kik 2017.11.20 347
1143 mybatis 에서 큐브리드 프로시져 콜 할때 오류 발생합니다. 6 file coolbyj 2020.09.15 347
1142 검색 단위 설정 해제하는 방법 문의드립니다. 2 마데카21 2019.08.23 346
1141 자바저장함수와 join 오류 1 file 퐁퐁 2017.09.13 345
Board Pagination Prev 1 ... 138 139 140 141 142 143 144 145 146 147 ... 200 Next
/ 200

Contact Cubrid

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