Database
SQL 명령어
jaamong
2021. 12. 31. 14:56
SQL 기본 명령어
- 데이터 정의어(Data Definition Language) : 테이블 생성, 변경, 삭제
- 데이터 조작어(Data Manipulation Language) : 데이터 삽입, 조회, 수정 삭제
- 데이터 제어어(Data Control Language) : 데이터 접근 권한 부여, 제거
- 트랜젝션 제어어(Transaction Control Language) : 데이터 조작어 명령어 실행, 최소, 임시저장
데이터 정의어(DDL)
테이블을 생성, 변경, 삭제할 때 사용하는 명령어
- 테이블은 각 열마다 반드시 1가지 데이터 타입으로 정의되어야 한다.
- 테이블은 각 열마다 제약 조건을 정의할 수 있다. (아래 나열된 조건보다 더 많음)
- PK(Primary Key) : 중복되어 나타날 수 없는 단일 값, NOT NULL
- NOT NULL : NULL 허용 X
- 테이블 생성
- CREATE TABLE 테이블명
- Ex.
CREATE TABLE TempTable ( //테이블 명 TempTable, 해당 이름의 테이블 생성 id INT PRIMARY KEY, name VARCHAR(20), signd DATE NOT NULL, status varchar(1) );
열 이름 데이터 타입 제약 조건 id int pk name varchar signd date not null status bit
- 열 추가
- ALTER TABLE 테이블명 ADD 추가할 열 이름 데이터타입
- Ex.
ALTER TABLE TempTable ADD age varchar(2); //TempTable 테이블에 age 열 추가
열 이름 데이터 타입 제약 조건 id int pk name varchar signd date not null status varchar age varchar
- 열 데이터 타입, 이름 변경
- ALTER TABLE 테이블명 MODIFY 바꾸고 싶은 열 이름 데이터타입
ALTER TABLE 테이블명 CHANGE 바꾸고 싶은 열 이름 바꿀 이름 데이터타입 - Ex.
ALTER TABLE TempTable MODIFY age VARCHAR(5); // 열 데이터 타입 변경 ALTER TABLE TempTable CHANGE age gender VARCHAR(2); // 열 이름 변경
열 이름 데이터 타입 제약 조건 id int pk name varchar signd date not null status varchar gender varchar
- ALTER TABLE 테이블명 MODIFY 바꾸고 싶은 열 이름 데이터타입
- 테이블명 변경
- ALTER TABLE 바꾸고자 하는 테이블명 RENAME 원하는 테이블 명
- Ex.
ALTER TABLE TempTable RENAME ReTable;
- 테이블 삭제
- DROP TABLE 테이블명
- Ex.
DROP TABLE ReTable;
데이터 조작어(DML)
테이블안의 데이터들을 조작하는 명령어이다.
- 데이터 삽입
- INSERT INTO 테이블명 VALUES (삽일할 데이터들); //열 순서대로 입력
- Ex.
INSERT INTO ReTable VALUES (1, '자몽', '2021-12-31', 'A' ,'1');
- 조건 위반
- PRIMARY KEY 제약 조건 위반 : 이미 id(pk)에 1번이 있음
INSERT INTO ReTable VALUES (1, 'ae자몽', '2021-12-31', 'A' ,'1'); - NOT NULL 제약 조건 위반 : signd는 NOT NULL임
INSERT INTO ReTable VALUES (2, 'ae자몽', NULL, 'A', '1'); - 데이터 타입 조건 위반 : 2는 int형으로 DATE 타입이 아님
INSERT INTO ReTable VALUES (2, 'ae자몽', 2, ,'A', '1');
- PRIMARY KEY 제약 조건 위반 : 이미 id(pk)에 1번이 있음
- 데이터 조회
- SELECT * FROM 테이블명
- Ex.
SELECT * FROM ReTable; //ReTable의 모든 열 조회 SELECT id FROM ReTable; //ReTable에서 id 열 조회 SELECT id AS Number FROM ReTable; //ReTable에서 id를 Number란 이름으로 조회(출력시 id가 아닌 Number로 출력됨)
- 데이터 수정
- UPDATE 테이블명 SET 변경하고자 하는 데이터
- Ex.
UPDATE ReTable SET status = 'D'; //ReTable의 status 열의 모든 값을 'D'로 변경 UPDATE ReTable SET status = 'A' WHERE name='자몽'; //ReTable에서 name이 '자몽'인 사람의 status만 'A'로 변경
- 데이터 삭제
- DELETE FROM 테이블명
- Ex.
DELETE FROM ReTable WHERE name = 'ae자몽'; //ReTable에서 name이 'ae자몽'인 데이터(row) 삭제 DELTE FROM ReTable; //ReTable 테이블은 남겨두고 안의 데이터들 삭제(모든 데이터 삭제)
데이터 제어어(DCL)
데이터 제어어는 권한을 제어하는 명령어로 데이터에 대한 접근 권한을 부여 및 제거할 수 있다.
데이터베이스 관리자(DBA)가 특정 사용자(User)에게 데이터 접근 권한을 부여 및 제거할 때 사용된다.
- 권한 부여/제거
- GRANT 권한 부여할 명령어들 ON 데이터베이스.테이블명 TO 권한을 부여할 사용자
REVOKE 권한 제거할 명령어들 ON 데이터베이스.테이블명 FROM 권한을 제거할 사용자 - Ex.
CREATE USER 'TEMP'@LOCALHOST IDENTIFIED BY 'TEMP'; //사용자 아이디 및 비밀번호(IDENTIFIED BY 뒤) 생성 //생성 후 SELECT * FROM USER; 해보면 TEMP가 추가된 것을 확인할 수 있음 SET PASSWORD FOR 'TEMP'@LOCALHOST = '0000'; //사용자 비밀번호 변경 /* 특정 권한 부여 */ /* TEMP에게 DBPRACTICE 데이터베이스의 ReTable 테이블에 대한 SELECT, DELETE 권한 부여 */ GRANT SELECT, DELETE ON DBPRACTICE.ReTable TO 'TEMP'@LOCALHOST; /* 특정 권한 제거 */ /* TEMP에게 주었던 권한 중 SELECT 권한을 제거 */ REVOKE SELECT ON DBPRACTICE.ReTable FROM 'TEMP'@LOCALHOST; /* 모든 권한 부여 */ GRANT ALL ON DBPRACTICE.ReTable TO 'TEMP'@LOCALHOST; /* 모든 권한 제거 */ REVOKE ALL ON DBPRACTICE.ReTable FROM 'TEMP'@LOCALHOST;
- GRANT 권한 부여할 명령어들 ON 데이터베이스.테이블명 TO 권한을 부여할 사용자
- 사용자 삭제
- DROP USER 삭제할 사용자 이름
- Ex.
DROP USER 'TEMP'@LOCALHOST; SELECT * FROM USER; //삭제 후 제거된 것을 확인 가능
트랜젝션 제어어(TCL)
TCL은 데이터 조작어(DML) 명령어를 실행, 취소, 임시저장할 때 사용하는 명령어이다.
트랜젝션(Tranaction)
트랜젝션은 분할할 수 없는 최소 단위이며 논리적인 작업 단위이다.
- 실행(COMMIT) : 모든 작업을 최종 실행
- 취소(ROLLBACK) : 모든 작업을 되돌림
- Ex.
spring boot에서 쿼리 작성을 할 때 commit을 하지 않아도 항상 최신 데이터로 처리되어있는 것을 확인했었는데, commit을 왜 할까? https://kimsg.tistory.com/258 /* BEGIN + ROLLBACK */ BEGIN; /* 트랜젝션 시작 */ INSERT INTO ReTable VALUES (3, 'JAAMONG', '2021-12-31', 'A', 1); //데이터 삽입 SELECT * FROM ReTable; // 삽입 확인 ROLLBACK; //취소 : 데이터 삽입 취소 SELECT * FROM ReTable; // 삽입 취소 확인 /* 트랜젝션 종료 */ /* BEGIN + COMMIT */ BEGIN; /* 트랜젝션 시작 */ INSERT INTO ReTable VALUES (3, 'JAAMONG', '2021-12-31', 'A', 1); //데이터 삽입 COMMIT; //실행 SELECT * FROM ReTable; // 삽입 확인 /* 트랜젝션 종료 */
- Ex.
- 임시 저장(SAVEPOINT)
- ROLLBACK 저장점을 지정하는 명령어
- 원하는 지점으로 ROLLBACK 할 수 있다.
- Ex.
BEGIN; /* 트랜젝션 시작 */ INSERT INTO ReTable VALUES ( , , ...); //대충 데이터 삽입했다고 하기 SAVEPOINT SP1; //SAVEPOINT 지정, SP1 : savepoint임 UPDATE ReTable SET name = '절대로뒤를돌아보지말어'; SAVEPOINT SP2; DELETE FROM ReTable; SAVEPOINT SP3; SELECT * FROM ReTable; /* 반영됐는지 조회 */ /* SAVEPOINT SP2로 ROLLBACK */ ROLLBACK TO SP2; SELECT * FROM ReTable; /* 조회하면 SP2로 돌아간 것을 확인할 수 있음, 조회 시 name '절대로뒤를돌아보지말어'가 존재할 것임 */