데이터 정의 언어(DDL), 데이터 조작 언어(DML), 데이터 제어 언어(DCL), 트랜잭션 제어 언어(TCL)는 SQL(Structured Query Language)을 통해 데이터베이스를 관리하고 조작하는 데 사용되는 주요 명령어 카테고리를 나타냅니다. 각 명령어의 역할과 기능은 다음과 같습니다.
이 네 가지 유형의 언어를 조합하여 데이터베이스를 정의, 조작, 제어 및 관리할 수 있습니다.
DDL(Data Definition Language)은 데이터베이스의 구조를 정의하거나 수정하기 위한 언어입니다. 이는 데이터베이스 객체를 생성, 변경, 삭제하는 명령어들을 포함하고 있습니다.
테이블, 뷰, 인덱스 등의 데이터베이스 객체를 생성합니다.
CREATE TABLE 테이블명 (
칼럼1 데이터타입,
칼럼2 데이터타입,
...
);
SQL이미 존재하는 테이블의 구조를 변경합니다.
ALTER TABLE 테이블명
ADD 칼럼명 데이터타입;
SQL테이블, 뷰, 인덱스 등의 데이터베이스 객체를 삭제합니다.
DROP TABLE 테이블명;
SQL테이블의 모든 데이터를 삭제하지만 테이블 구조는 유지합니다.
TRUNCATE TABLE 테이블명;
SQL특정 데이터베이스 객체에 대한 주석을 추가합니다.
COMMENT ON TABLE 테이블명 IS '이 테이블은 예제입니다.';
SQL테이블, 칼럼 등의 이름을 변경합니다.
ALTER TABLE 이전테이블명 RENAME TO 새테이블명;
SQL이러한 DDL 명령어를 사용하여 데이터베이스의 구조를 정의하고 변경함으로써 데이터를 효과적으로 관리할 수 있습니다.
데이터 조작 언어 (DML)은 데이터베이스에서 저장된 데이터를 조회하거나 조작하는 데 사용되는 언어입니다. DML 명령어는 데이터베이스에서 정보를 검색하고, 새로운 데이터를 추가하며, 기존 데이터를 수정하거나 삭제하는 등의 작업을 수행합니다.
SELECT 열1, 열2, ...
FROM 테이블이름
WHERE 조건;
SQLINSERT INTO 테이블이름 (열1, 열2, ...)
VALUES (값1, 값2, ...);
SQLUPDATE 테이블이름
SET 열1 = 값1, 열2 = 값2, ...
WHERE 조건;
SQLDELETE FROM 테이블이름
WHERE 조건;
SQLMERGE INTO 대상테이블 USING 원본테이블
ON (조인조건)
WHEN MATCHED THEN
UPDATE SET 열1 = 값1, 열2 = 값2, ...
WHEN NOT MATCHED THEN
INSERT (열1, 열2, ...)
VALUES (값1, 값2, ...);
SQLDML 명령어는 데이터베이스의 내용을 유연하게 다룰 수 있도록 해주며, 응용 프로그램이나 사용자 요구에 따라 데이터를 효과적으로 관리할 수 있게 합니다.
데이터 제어 언어 (DCL)은 데이터베이스 객체에 대한 액세스 권한을 제어하는 데 사용되는 언어입니다. DCL은 주로 데이터베이스의 보안 및 권한 부여와 관련된 작업을 수행합니다. 이는 특정 사용자나 역할이 데이터베이스 객체에 대한 어떤 작업을 수행할 수 있는지 결정하는 데 사용됩니다.
GRANT 권한 ON 테이블이름 TO 사용자이름 또는 역할이름;
SQLREVOKE 권한 ON 테이블이름 FROM 사용자이름 또는 역할이름;
SQLDENY 권한 ON 테이블이름 TO 사용자이름 또는 역할이름;
SQLDCL 명령어를 사용하여 데이터베이스에 대한 보안 정책을 설정하고 권한을 관리함으로써 데이터베이스의 안전성을 유지할 수 있습니다. 이를 통해 민감한 정보에 대한 접근을 통제하고, 데이터의 무단 수정이나 삭제를 방지할 수 있습니다.
트랜잭션 제어 언어 (TCL)는 데이터베이스 트랜잭션을 관리하는 데 사용되는 언어입니다. TCL 명령어를 사용하여 트랜잭션을 시작하고 완료하며, 트랜잭션의 일부를 롤백하거나 커밋하는 등의 작업을 수행할 수 있습니다.
COMMIT;
SQLROLLBACK;
SQLSAVEPOINT 저장점이름;
ROLLBACK TO SAVEPOINT 저장점이름;
SQLTCL 명령어를 사용하여 트랜잭션을 명시적으로 제어함으로써 데이터베이스에서 일관성과 안정성을 유지할 수 있습니다. 특히, 예외 발생 시 롤백을 통해 트랜잭션의 일관성을 보장하거나, 커밋을 통해 트랜잭션의 변경을 영구화할 수 있습니다.
DDL은 데이터베이스 구조 정의, DML은 데이터 조작, DCL은 권한 제어, TCL은 트랜잭션 관리에 사용되는 SQL 명령어 카테고리입니다. CREATE, ALTER, DROP은 DDL에 속하며, 데이터 조회, 삽입, 수정, 삭제는 DML에 해당합니다. 권한 부여 및 회수는 DCL을 통해 이루어지며, 트랜잭션 커밋 및 롤백은 TCL 명령어로 처리됩니다. 이 네 가지 언어를 조합하여 데이터베이스를 효과적으로 관리할 수 있습니다.
컴포넌트 스캔이란? 컴포넌트 스캔(Component Scan)은 스프링 프레임워크가 특정 패키지를 탐색하면서, 스캔 대상에 해당하는 클래스를 찾아…
스프링 빈이란? 스프링 빈(Spring Bean)은 스프링 IoC(Inversion of Control) 컨테이너가 관리하는 자바 객체를 의미합니다. 간단히…
스프링 컨테이너(Spring Container)란? 스프링 컨테이너는 스프링 프레임워크에서 가장 핵심적인 부분으로, IoC(Inversion of Control) 개념을 기반으로…
Queue란 무엇인가? Java에서 Queue는 데이터 구조의 일종으로, 데이터를 선입선출(FIFO, First-In-First-Out) 방식으로 처리합니다. 이 글에서는 Queue의…
Stack이란 무엇인가? Java에서 Stack은 자료구조의 한 종류로, 데이터를 순서대로 쌓아 올리는 형태로 운영됩니다. 컴퓨터 과학에서…
소개 자바에서 Map 인터페이스는 키(Key)와 값(Value)의 쌍을 저장하는 자료구조입니다. 이는 연관 배열이라고도 불리며, 각 키는…