sql-logo
데이터 정의 언어(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 명령어로 처리됩니다. 이 네 가지 언어를 조합하여 데이터베이스를 효과적으로 관리할 수 있습니다.
인터넷 네트워크란? "인터넷(Internet)"이라는 단어는 "인터네트워크(Internetwork)"의 줄임말입니다. 즉, 여러 개의 네트워크가 상호 연결되어 전 세계적으로 하나의…
스프링 빈(Spring Bean)과 IoC 컨테이너 스프링 프레임워크의 핵심 철학은 IoC(Inversion of Control) 컨테이너를 통해 객체(빈,…
스프링 빈이란? 스프링 프레임워크에서 "스프링 빈(Bean)"이란, IoC(Inversion of Control) 컨테이너가 직접 관리하는 객체를 말합니다. @Component,…
의존성 주입(Dependency Injection)이란? 프로그램을 개발하다 보면, 여러 클래스나 객체들은 서로 필요한 기능을 사용하기 위해 관계를…
컴포넌트 스캔이란? 컴포넌트 스캔(Component Scan)은 스프링 프레임워크가 특정 패키지를 탐색하면서, 스캔 대상에 해당하는 클래스를 찾아…
스프링 빈이란? 스프링 빈(Spring Bean)은 스프링 IoC(Inversion of Control) 컨테이너가 관리하는 자바 객체를 의미합니다. 간단히…