기타
2016.03.03 01:04

CSQL 인터프리터 사용방법

조회 수 18425 추천 수 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 종료/나가기

 


  1. CUBRID Windows 설치 또는 재설치 후 큐브리드 서비스 문제 해결 가이드

    Date2024.11.15 CategoryWindows By정만영 Views164
    Read More
  2. [linux] wget으로 제품 다운로드 시 "wget: unable to resolve host address ‘ftp.cubrid.org’" 해결방

    Date2021.07.02 CategoryInstall By큐브리드_김주현 Views3308
    Read More
  3. [10.2 path] - 생성된 view구문을 'show create view' 수행 시 정상적으로 출력되지 않던 이슈 patch

    Date2020.11.09 Category기타 By큐브리드_김주현 Views1617
    Read More
  4. ERwin을 이용한 CUBRID 포워드 엔지니어링

    Date2020.07.14 Category기타 By민순 Views3271
    Read More
  5. ERwin을 이용한 CUBRID 리버스 엔지니어링

    Date2020.07.13 Category기타 By민순 Views4456
    Read More
  6. <주의> 생성한 DB볼륨을 절대! 삭제하지 말자

    Date2019.09.30 CategoryLinux By큐브리드_김주현 Views2284
    Read More
  7. 큐브리드10.1 에서 윤초 지원 옵션 사용하기

    Date2017.09.13 Category기타 By최광일 Views1990
    Read More
  8. 따라하면 쉬운 compactdb 사용법

    Date2017.07.01 Category기타 By허서진 Views3247
    Read More
  9. 리눅스에서 top 명령어를 통한 CPU 점유율 확인 및 측정하기

    Date2017.06.02 CategoryLinux By정훈 Views88420
    Read More
  10. JDBC를 사용한 다중화 구성 SELECT Query 부하 분산 가이드

    Date2017.03.30 CategoryJava By윤준수 Views4660
    Read More
  11. 다중컬럼 조건에 대한 인라인뷰 처리방안

    Date2016.12.27 Category튜닝 By박동윤 Views6609
    Read More
  12. tomcat8.0(DBCP2)과 CUBRID 연동하기

    Date2016.07.01 CategoryJava By손승일 Views16400
    Read More
  13. LIMIT절을 사용하여 SQL문을 간결하게 작성하고, 부분범위 처리를 유도하자.

    Date2016.06.29 Category튜닝 By권호일 Views16468
    Read More
  14. CUBRID에서 Java AddBatch 사용

    Date2016.06.28 CategoryJava By엄기호 Views9023
    Read More
  15. PyCharm을 이용한 CUBRID, Django 연동 가이드

    Date2016.04.11 Category기타 By진우진 Views8780
    Read More
  16. CSQL 인터프리터 사용방법

    Date2016.03.03 Category기타 By정만영 Views18425
    Read More
  17. 데이터 확인에 정규표현식을 사용 해 보자.

    Date2016.03.01 Category기타 By성진 Views13774
    Read More
  18. 리소스를 제한(limits.conf) 하여 DB서버를 관리하자

    Date2015.12.31 CategoryLinux By주현 Views27696
    Read More
  19. CUBRID Migration Toolkit을 이용한 단계별 마이그레이션 진행 방법

    Date2015.12.15 Category기타 By진우진 Views10384
    Read More
  20. 알고 보면 쉬운 cubrid lockdb 유틸리티

    Date2015.12.08 Category기타 By김승훈 Views13211
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

Contact Cubrid

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

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

나눔고딕 사이트로 가기

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5