Categories: DataBase

SQL DDL, DML, DCL, TCL 명령어 종류 및 사용법

DDL, DML, DCL, TCL 이란?

데이터 정의 언어(DDL), 데이터 조작 언어(DML), 데이터 제어 언어(DCL), 트랜잭션 제어 언어(TCL)는 SQL(Structured Query Language)을 통해 데이터베이스를 관리하고 조작하는 데 사용되는 주요 명령어 카테고리를 나타냅니다. 각 명령어의 역할과 기능은 다음과 같습니다.

  1. DDL (Data Definition Language – 데이터 정의 언어):
    • 데이터베이스의 구조를 정의하거나 수정하는 데 사용됩니다.
    • 예: CREATE, ALTER, DROP 등의 명령어가 여기에 속합니다.
  2. DML (Data Manipulation Language – 데이터 조작 언어):
    • 데이터를 조회, 삽입, 수정 또는 삭제하는 데 사용됩니다.
    • 예: SELECT, INSERT, UPDATE, DELETE 등의 명령어가 여기에 속합니다.
  3. DCL (Data Control Language – 데이터 제어 언어):
    • 데이터베이스의 사용자에 대한 권한을 제어하는 데 사용됩니다.
    • 예: GRANT, REVOKE 등의 명령어가 여기에 속합니다.
  4. TCL (Transaction Control Language – 트랜잭션 제어 언어):
    • 트랜잭션의 처리를 제어하는 데 사용됩니다.
    • 예: COMMIT, ROLLBACK 등의 명령어가 여기에 속합니다.

이 네 가지 유형의 언어를 조합하여 데이터베이스를 정의, 조작, 제어 및 관리할 수 있습니다.

DDL (Data Definition Language)

DDL(Data Definition Language)은 데이터베이스의 구조를 정의하거나 수정하기 위한 언어입니다. 이는 데이터베이스 객체를 생성, 변경, 삭제하는 명령어들을 포함하고 있습니다.

CREATE (생성)

테이블, 뷰, 인덱스 등의 데이터베이스 객체를 생성합니다.

SQL
CREATE TABLE 테이블명 (
  칼럼1 데이터타입,
  칼럼2 데이터타입,
  ...
);
SQL

ALTER (변경)

이미 존재하는 테이블의 구조를 변경합니다.

SQL
ALTER TABLE 테이블명
ADD 칼럼명 데이터타입;
SQL

DROP (삭제)

테이블, 뷰, 인덱스 등의 데이터베이스 객체를 삭제합니다.

SQL
DROP TABLE 테이블명;
SQL

TRUNCATE (데이터 초기화)

테이블의 모든 데이터를 삭제하지만 테이블 구조는 유지합니다.

SQL
TRUNCATE TABLE 테이블명;
SQL

COMMENT (주석)

특정 데이터베이스 객체에 대한 주석을 추가합니다.

SQL
COMMENT ON TABLE 테이블명 IS '이 테이블은 예제입니다.';
SQL

RENAME (이름 변경)

테이블, 칼럼 등의 이름을 변경합니다.

SQL
ALTER TABLE 이전테이블명 RENAME TO 새테이블명;
SQL

이러한 DDL 명령어를 사용하여 데이터베이스의 구조를 정의하고 변경함으로써 데이터를 효과적으로 관리할 수 있습니다.

DML (Data Manipulation Language)

데이터 조작 언어 (DML)은 데이터베이스에서 저장된 데이터를 조회하거나 조작하는 데 사용되는 언어입니다. DML 명령어는 데이터베이스에서 정보를 검색하고, 새로운 데이터를 추가하며, 기존 데이터를 수정하거나 삭제하는 등의 작업을 수행합니다.

SELECT (조회)

  • SELECT: 데이터베이스에서 정보를 검색하는 데 사용됩니다. 특정 테이블의 열이나 특정 조건을 지정하여 데이터를 선택합니다.
  • FROM: 데이터를 검색할 테이블의 이름을 지정합니다.
  • WHERE: 특정 조건에 맞는 데이터를 선택합니다.
SQL
SELECT 열1, 열2, ...
FROM 테이블이름
WHERE 조건;
SQL

INSERT (삽입)

  • INSERT INTO: 새로운 데이터를 데이터베이스에 추가합니다.
  • VALUES: 삽입할 데이터의 값들을 지정합니다.
SQL
INSERT INTO 테이블이름 (열1, 열2, ...)
VALUES (값1, 값2, ...);
SQL

UPDATE (갱신)

  • UPDATE: 이미 존재하는 데이터를 수정합니다.
  • SET: 수정할 열과 해당 값을 지정합니다.
SQL
UPDATE 테이블이름
SET 열1 = 값1, 열2 = 값2, ...
WHERE 조건;
SQL

DELETE (삭제)

  • DELETE FROM: 데이터베이스에서 특정 조건에 맞는 데이터를 삭제합니다.
SQL
DELETE FROM 테이블이름
WHERE 조건;
SQL

MERGE (병합)

  • MERGE INTO: 두 테이블 간의 일치하는 행을 업데이트하거나 없으면 삽입하는 복잡한 작업을 수행합니다.
SQL
MERGE INTO 대상테이블 USING 원본테이블
ON (조인조건)
WHEN MATCHED THEN
  UPDATE SET 열1 = 값1, 열2 = 값2, ...
WHEN NOT MATCHED THEN
  INSERT (열1, 열2, ...)
  VALUES (값1, 값2, ...);
SQL

DML 명령어는 데이터베이스의 내용을 유연하게 다룰 수 있도록 해주며, 응용 프로그램이나 사용자 요구에 따라 데이터를 효과적으로 관리할 수 있게 합니다.

DCL (Data Control Language)

데이터 제어 언어 (DCL)은 데이터베이스 객체에 대한 액세스 권한을 제어하는 데 사용되는 언어입니다. DCL은 주로 데이터베이스의 보안 및 권한 부여와 관련된 작업을 수행합니다. 이는 특정 사용자나 역할이 데이터베이스 객체에 대한 어떤 작업을 수행할 수 있는지 결정하는 데 사용됩니다.

GRANT (부여)

  • GRANT: 특정 사용자나 역할에 대한 특정 권한을 부여합니다. 권한은 데이터베이스 객체에 대한 읽기, 쓰기, 실행 등의 작업을 포함할 수 있습니다.
  • WITH GRANT OPTION: 부여된 권한을 다른 사용자에게 다시 부여할 수 있는 권한을 함께 부여합니다.
SQL
GRANT 권한 ON 테이블이름 TO 사용자이름 또는 역할이름;
SQL

REVOKE (회수)

  • REVOKE: 사용자나 역할에게 부여된 권한을 회수합니다. 이를 통해 데이터베이스 객체에 대한 액세스를 제한하거나 취소할 수 있습니다.
SQL
REVOKE 권한 ON 테이블이름 FROM 사용자이름 또는 역할이름;
SQL

DENY (거부)

  • DENY: 특정 사용자나 역할에게 특정 권한을 명시적으로 거부합니다. 다른 부여된 권한에 대해 우선 순위를 부여할 수 있습니다.
SQL
DENY 권한 ON 테이블이름 TO 사용자이름 또는 역할이름;
SQL

DCL 명령어를 사용하여 데이터베이스에 대한 보안 정책을 설정하고 권한을 관리함으로써 데이터베이스의 안전성을 유지할 수 있습니다. 이를 통해 민감한 정보에 대한 접근을 통제하고, 데이터의 무단 수정이나 삭제를 방지할 수 있습니다.

TCL (Transaction Control Language)

트랜잭션 제어 언어 (TCL)는 데이터베이스 트랜잭션을 관리하는 데 사용되는 언어입니다. TCL 명령어를 사용하여 트랜잭션을 시작하고 완료하며, 트랜잭션의 일부를 롤백하거나 커밋하는 등의 작업을 수행할 수 있습니다.

COMMIT (커밋)

  • COMMIT: 트랜잭션의 모든 변경 사항을 확정하고 데이터베이스에 영구적으로 반영합니다.
  • 커밋 명령어를 사용하면 트랜잭션이 성공적으로 완료되었음을 나타내며, 변경 사항이 데이터베이스에 영구적으로 저장됩니다.
SQL
COMMIT;
SQL

ROLLBACK (롤백)

  • ROLLBACK: 트랜잭션의 모든 변경 사항을 취소하고 이전 상태로 되돌립니다.
  • 롤백 명령어를 사용하여 트랜잭션이 실패하거나 취소되어야 할 때 트랜잭션의 일부 또는 전체를 취소할 수 있습니다.
SQL
ROLLBACK;
SQL

SAVEPOINT (저장점)

  • SAVEPOINT: 트랜잭션 내에서 중간 저장점을 설정합니다. 트랜잭션 중 일부를 롤백할 때 저장점부터 롤백할 수 있습니다.
  • ROLLBACK TO SAVEPOINT: 설정한 저장점으로 트랜잭션의 일부를 롤백합니다.
SQL
SAVEPOINT 저장점이름;
ROLLBACK TO SAVEPOINT 저장점이름;
SQL

TCL 명령어를 사용하여 트랜잭션을 명시적으로 제어함으로써 데이터베이스에서 일관성과 안정성을 유지할 수 있습니다. 특히, 예외 발생 시 롤백을 통해 트랜잭션의 일관성을 보장하거나, 커밋을 통해 트랜잭션의 변경을 영구화할 수 있습니다.

결론

DDL은 데이터베이스 구조 정의, DML은 데이터 조작, DCL은 권한 제어, TCL은 트랜잭션 관리에 사용되는 SQL 명령어 카테고리입니다. CREATE, ALTER, DROP은 DDL에 속하며, 데이터 조회, 삽입, 수정, 삭제는 DML에 해당합니다. 권한 부여 및 회수는 DCL을 통해 이루어지며, 트랜잭션 커밋 및 롤백은 TCL 명령어로 처리됩니다. 이 네 가지 언어를 조합하여 데이터베이스를 효과적으로 관리할 수 있습니다.

suover

Recent Posts

Spring 스프링 컴포넌트 스캔(Component Scan)이란?

컴포넌트 스캔이란? 컴포넌트 스캔(Component Scan)은 스프링 프레임워크가 특정 패키지를 탐색하면서, 스캔 대상에 해당하는 클래스를 찾아…

2주 ago

Spring 스프링 빈(Bean)이란?

스프링 빈이란? 스프링 빈(Spring Bean)은 스프링 IoC(Inversion of Control) 컨테이너가 관리하는 자바 객체를 의미합니다. 간단히…

3주 ago

Spring 스프링 컨테이너(Spring Container)란?

스프링 컨테이너(Spring Container)란? 스프링 컨테이너는 스프링 프레임워크에서 가장 핵심적인 부분으로, IoC(Inversion of Control) 개념을 기반으로…

1개월 ago

Java 자바 큐(Queue) 개념과 사용법

Queue란 무엇인가? Java에서 Queue는 데이터 구조의 일종으로, 데이터를 선입선출(FIFO, First-In-First-Out) 방식으로 처리합니다. 이 글에서는 Queue의…

1개월 ago

Java 자바 스택(Stack) 개념과 사용법

Stack이란 무엇인가? Java에서 Stack은 자료구조의 한 종류로, 데이터를 순서대로 쌓아 올리는 형태로 운영됩니다. 컴퓨터 과학에서…

2개월 ago

Java 자바 Map – HashMap, TreeMap, LinkedHashMap 정리

소개 자바에서 Map 인터페이스는 키(Key)와 값(Value)의 쌍을 저장하는 자료구조입니다. 이는 연관 배열이라고도 불리며, 각 키는…

2개월 ago