데이터 정의 언어(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 명령어로 처리됩니다. 이 네 가지 언어를 조합하여 데이터베이스를 효과적으로 관리할 수 있습니다.
소개 자바에서 Set은 중복을 허용하지 않는 데이터 집합을 의미합니다. List와 달리 동일한 요소를 여러 번…
해시(Hash)란 무엇인가? 해시(Hash)는 자바 프로그래밍에서 빠르고 효율적인 데이터 저장 및 검색을 위한 핵심적인 개념입니다. 이…
LinkedList란 무엇인가? LinkedList는 자바에서 유용하게 사용되는 자료구조 중 하나로, 연결 리스트 방식을 이용하여 데이터를 관리하는…
ArrayList란 무엇인가? ArrayList는 자바에서 가장 널리 사용되는 컬렉션 중 하나로, 가변 크기의 배열을 구현한 클래스입니다.…
제네릭(Generic)이란? 자바 제네릭은 코드의 재사용성을 높이고 타입 안전성을 보장하는 중요한 개념입니다. 이 블로그 글에서는 자바…