Background Image
기타
2016.03.03 01:04

CSQL 인터프리터 사용방법

조회 수 17599 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

CUBRID에서 SQL 문을 실행하는 방법은 GUI(Graphical User Interface) 기반의 CUBRID Query Browser를 이용하거나, 콘솔 기반의 CSQL 인터프리터를 이용방법이 있다, CSQL CUBRID 설치한 계정으로 로그인하여 콘솔에서 명령어 방식으로 SQL 문을 사용할 수 있는 프로그램으로 이 문서에서는 CSQL 인터프리터의 간단한 사용법과 자주 사용되는 옵션을 설명하고자 한다.



1, CSQL 인터프리터 소개

CSQL 인터프리터는 CUBRID와 함께 설치되며, 대화형(interactive) 방식과 일괄 수행(batch) 방식으로 SQL 질의를 수행하고 수행 결과를 조회할 수 있는 프로그램이다.

CSQL 인터프리터는 CUBRID 데이터베이스에 접속하여 SQL 문을 통해 다양한 작업을 수행이 가능한데 예를들면 테이블 스키마 조회, SQL 문을 이용하여 데이터베이스 조회, 갱신, 삭제 등의 작업과 조회 결과의 저장 혹은 출력, SQL 기반으로 만들어진 파일 실행, 다양한 데이터베이스 정보(스키마, 트리거, 지연 트리거, workspace, 잠금, 통계) 조회등이 가능하다.

 

2, CSQL 인터프리터 모드

CSQL 인터프리터는 독립 모드(Standalone Mode), 클라이언트/서버 모드(Client/Server Mode), 시스템 관리자 모드(System admin Mode)를 제공한다.

2-1, 독립 실행 모드는 데이터베이스 서버 프로세스 정지된 상태에서 해당 데이터베이스를 대상으로 SQL 문을 실행할 수 있는데 독립 모드는 한 사용자만이 접근이 가능하므로 DBA (Database Administrator)가 관리 작업을 위해 수행하는데 적합한 모드이다,

Ex) csql –S –u dba demodb

2-2, 클라이언트/서버 모드는 데이터베이스 서버 프로세스 구동된 상태에서 해당 데이터베이스 서버 프로세스에 접속하는 방식으로 여러 사용자가 같이 사용할 수 있는 모드이다.

Ex) csql –C –u dba demodb

2-3, 시스템 관리자 모드는 CSQL 인터프리터를 통해 특별한 관리 작업을 수행하기 위해 사용되는 모드로 데이터베이스 서버 프로세스가 구동 상태에서 서버 접속 개수(max_clients)가 값을 초과하더라도 CSQL 인터프리터에서 시스템 관리자 모드로 접속하면 추가로 단 하나의 연결을 허용한다. (체크 포인트를 수행하거나 트랜잭션 모니터링을 종료 등의 작업을 수행할 수 있다.)

Ex) csql –C -u dba --sysadm demodb

 

3, CSQL 옵션과 접속방법

csql 유틸리티는 필요에 따라 옵션을 설정할 수 있고 접속하고자 하는 데이터베이스 이름을 인수로 지정한다.

Syntax: csql [options] database_name

Options: 프롬프트 상에서 옵션 목록을 보려면, 다음과 같이 옵션을 적용할 데이터베이스를 지정하지 않고 csql 유틸리티를 실행한다.

Ex) cubrid$>csql

-S, --SA-mode

-C, --CS-mode

-u, --user=ARG

-p, --password=ARG

-e, --error-continue

-i, --input-file=ARG

-o, --output-file=ARG

-s, --single-line

-c, --command=ARG

-l, --line-output

-r, --read-only

--string-width

--no-auto-commit

--no-pager

--no-single-line

--no-trigger-action

DB 프로세스 정지 시 사용(독립 실행 모드)

DB 프로세스 구동 시 사용(클라이언트/서버 모드)

DB 접속 계정 정보

DB password 정보

SQL 문장에 오류가 있어도 무시하고 수행

배치 모드에서 입력파일 이름 지정하여 수행

질의 수행 결과를 파일로 저장

여러 개의 SQL문을 하나씩 수행(-i 옵션과 같이 사용)

CSQL 명령 시 SQL문을 직접 입력해 수행

질의 수행 결과를 라인 단위로 출력

읽기 전용으로 CSQL 접속

출력 길이를 제한하는 옵션

CSQL 접속 시 auto commit off

질의 수행 결과를 일괄적으로 출력

질의문 여러 개를 ;xr or ;r 세션 명령어로 한번에 수행

트리거를 비활성화로 동작

 

4, CSQL 접속방법

4-1, 내부(로컬) 호스트 접속

다음은 로컬 서버에 위치한 데이터베이스에 접속하는 csql 유틸리티 구문이다.

Ex) csql –C –u public database_name@localhost

4-2, 외부(원격) 호스트 접속

다음은 192.168.0.111 위치의 원격 호스트에 존재하는 demodb 에 접속하여 csql 유틸리티를 호출하는 예제이다.

Ex) csql –C –u public database_name@192.168.0.111

4-3, CSQL 접속 제약

- 원격 호스트와 로컬 호스트에 설치된 CUBRID는 동일한 버전이어야 한다.

- 원격 호스트와 로컬 호스트의 마스터 프로세스가 사용하는 포트 번호가 동일해야 한다.

 

5, CSQL 옵션 사용 방법

CSQL 접속 시 -u는 접속할 사용자 계정을 지정하는 옵션이고 -p는 계정 비밀번호를 입력하는 옵션으로 -p 옵션이 생략된 경우는 CSQL 실행 후 Password를 직접 입력하면 된다.

5-1, -i 옵션 사용방법은 수행할 질의를 파일명(infail)로 만들어 사용하는데 질의별로 마지막은 세미콜론(;) 붙여 입력한다. 

Ex) csql –C –u db_user –p ‘password’ -i infile demodb

5-2, -o 옵션을 이용하여 CSQL에서 질의 수행한 결과를 파일로 저장할 수 있다.

Ex) csql –C –u db_user –p ‘password’ -o outfile demodb

5-3, -s 옵션은 -i 옵션과 함께 사용하는 옵션으로, -s 옵션을 지정하면 파일에 입력된 여러 개의 SQL 문을 하나씩 나누어 수행한다.

Ex) csql –C –u db_user –p ‘password’ -s -i infile demodb

5-4, -c 옵션을 이용하여 셸 상에서 하나 이상의 SQL 문을 직접 수행한다. 이 때, 각 문장은 세미콜론(;)으로 구분한다.

Ex) csql –C –u db_user –p ‘password’ -c 'select * from olympic;select * from stadium' demodb

5-5, -l 옵션을 이용하여 SQL 문을 실행한 결과 레코드의 SELECT 리스트 값들을 CSQL 인터프리터에서 라인 단위로 나누어서 출력한다.

Ex) csql –C –u db_user –p ‘password’ -l demodb

5-6 --no-auto-commit 옵션을 지정하지 않으면 기본적으로 CSQL 인터프리터는 자동 커밋 모드로 작동되고, 입력된 SQL 문이 실행될 때마다 자동으로 커밋 되는데, 자동 커밋을 방지하기가 필요하면 --no-auto-commit 옵션을 사용해 CSQL을 접속한다.

Ex) csql –C –u db_user –p ‘password’ --no-auto-commit demodb

 

6, CSQL 세션 명령어

CSQL 인터프리터에 접속 이후 제어하는 명령어가 있는데 이를 세션 명령어라고 한다. 모든 세션 명령어는 반드시 세미콜론(;)으로 시작해야 한다, CSQL 세션 명령어들은 아래와 같이 ;help를 수행하면 세션 명령어를 확인할 수 있고 SQL 마지막에 세미콜론(;)을 붙이면 질의가 수행된다.

Ex) csql –C –u dba –p ‘password’ demodb

Csq>;help

=== <Help: Session Command Summary> ===

:.

   ;EXit                        - exit program.

   ;CLear                       - clear command buffer.

   ;EDIT                        - invoke system editor with command buffer.

   ;LISt                         - display the content of command buffer.

   ;RUn                         - execute sql in command buffer.

   ;Xrun                        - execute sql in command buffer,

:

csql> select * from event where rownum < 5; à SQL 마지막에 세미콜론(;)
=== <Result of SELECT Command in Line 1> ===
         code  sports                name                  gender                    players
=========================================================
        20421  'Wrestling'           'Greco-Roman 97kg'    'M'                             1
        20420  'Wrestling'           'Greco-Roman 96kg'    'M'                             1
        20419  'Wrestling'           'Greco-Roman 90kg'    'M'                             1
        20418  'Wrestling'           'Greco-Roman -90 kg'  'M'                             1

csql> ;sc event à 테이블 스키마 정보 확인
=== <Help: Schema of a Class> ===
 <Class Name>
     event
 <Attributes>
     code                 INTEGER NOT NULL
     sports               CHARACTER VARYING(50)
     name                 CHARACTER VARYING(50)
     gender               CHARACTER(1)
     players              INTEGER
 <Constraints>
     PRIMARY KEY pk_event_code ON event (code)

csql> ;exit à CSQL 종료/나가기

 


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
166 Install [linux] wget으로 제품 다운로드 시 "wget: unable to resolve host address ‘ftp.cubrid.org’" 해결방 큐브리드_김주현 2021.07.02 2900
165 기타 [10.2 path] - 생성된 view구문을 'show create view' 수행 시 정상적으로 출력되지 않던 이슈 patch 큐브리드_김주현 2020.11.09 1309
164 기타 ERwin을 이용한 CUBRID 포워드 엔지니어링 file 민순 2020.07.14 2896
163 기타 ERwin을 이용한 CUBRID 리버스 엔지니어링 file 민순 2020.07.13 4073
162 Linux <주의> 생성한 DB볼륨을 절대! 삭제하지 말자 큐브리드_김주현 2019.09.30 2012
161 기타 큐브리드10.1 에서 윤초 지원 옵션 사용하기 최광일 2017.09.13 1766
160 기타 따라하면 쉬운 compactdb 사용법 file 허서진 2017.07.01 2957
159 Linux 리눅스에서 top 명령어를 통한 CPU 점유율 확인 및 측정하기 file 정훈 2017.06.02 85302
158 Java JDBC를 사용한 다중화 구성 SELECT Query 부하 분산 가이드 file 윤준수 2017.03.30 4335
157 튜닝 다중컬럼 조건에 대한 인라인뷰 처리방안 2 박동윤 2016.12.27 6316
156 Java tomcat8.0(DBCP2)과 CUBRID 연동하기 손승일 2016.07.01 16059
155 튜닝 LIMIT절을 사용하여 SQL문을 간결하게 작성하고, 부분범위 처리를 유도하자. 권호일 2016.06.29 16038
154 Java CUBRID에서 Java AddBatch 사용 엄기호 2016.06.28 8713
153 기타 PyCharm을 이용한 CUBRID, Django 연동 가이드 file 진우진 2016.04.11 8524
» 기타 CSQL 인터프리터 사용방법 정만영 2016.03.03 17599
151 기타 데이터 확인에 정규표현식을 사용 해 보자. 성진 2016.03.01 13391
150 Linux 리소스를 제한(limits.conf) 하여 DB서버를 관리하자 1 주현 2015.12.31 27292
149 기타 CUBRID Migration Toolkit을 이용한 단계별 마이그레이션 진행 방법 file 진우진 2015.12.15 10055
148 기타 알고 보면 쉬운 cubrid lockdb 유틸리티 file 김승훈 2015.12.08 12742
147 Linux 가상머신 환경에서 리눅스 및 큐브리드 설치 가이드 file 이경오 2015.07.14 13786
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

Contact Cubrid

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