1. 지난 포스팅 리마인드
•
IT 회사 RDB 만들기
◦
부서, 사원, 프로젝트 관련 정보들을 저장할 수 있는 RDB를 지난 포스팅에서 만들어보았다.
◦
RDBMS는 MySQL(InnoDB)를 사용
1.1. IT 회사 RDB 스키마
•
DEPARTMENT
id | name | leader_id |
•
EMPLOYEE
id | name | birth_date | sex | position | salary | dept_id |
•
PROJECT
id | name | leader_id | start_date | end_date |
•
WORKS_ON
empl_id | proj_id |
2. 데이터 추가하기 (INSERT)
2.1. 삽입 명령 (INSERT statement)
•
데이터를 하나만 추가할 때
INSERT INTO table_name VALUES (comma-separated all values);
SQL
복사
•
원하는 속성을 임의로 지정해서 데이터를 하나만 추가할 때
INSERT INTO table_name (attributes list)
VALUES (attributes list 순서와 동일하게 comma-separated values);
SQL
복사
•
데이터 여러 개를 추가할 때
INSERT INTO table_name VALUES (…, ..), (…, ..), (…, ..);
SQL
복사
2.2. 실습
•
테이블 생성
create table EMPLOYEE (
id INT PRIMARY KEY,
name VARCHAR(30) NOT NULL,
birth_date DATE,
sex CHAR(1) CHECK (sex in ('M', 'F')),
position VARCHAR(10),
salary INT DEFAULT 50000000,
dept_id INT,
FOREIGN KEY (dept_id) references DEPARTMENT(id)
on delete SET NULL on update CASCADE,
CHECK (salary >= 50000000)
);
SQL
복사
•
MESSI 직원 추가
INSERT INTO EMPLOYEE
VALUES (1, "MESSI", "1987-02-01", "M", "DEV_BACK", 100000000, null);
SQL
복사
Output
•
JANE 직원 추가 (PRIMARY KEY Key constraints 위배)
INSERT INTO EMPLOYEE
VALUES (1, "JANE", "1996-05-05", "F", "DEV_FRONT", 900000000, null);
SQL
복사
Output
•
JANE 직원 추가 (CHECK constraint 위배)
INSERT INTO EMPLOYEE
VALUES (2, "JANE", "1996-05-05", "F", "DEV_FRONT", 3000, null);
SQL
복사
Output
•
JANE 직원 추가 (FOREIGN KEY Referential integrity constraint 위배)
INSERT INTO EMPLOYEE
VALUES (1, "JANE", "1996-05-05", "F", "DEV_FRONT", 900000000, 111);
SQL
복사
Output
•
JANE 직원 추가
INSERT INTO EMPLOYEE
VALUES (1, "JANE", "1996-05-05", "F", "DEV_FRONT", 900000000, null);
SQL
복사
Output
•
JENNY 직원 추가
INSERT INTO EMPLOYEE (name, birth_date, sex, position, id)
VALUES ("JENNY", "2000-10-12", "F", "DEV_BACK", 3);
SQL
복사
Output
•
직원 여러 명 한꺼번에 추가
INSERT INTO EMPLOYEE VALUES
(4, "BROWN", "1996-03-13", "M", "CEO", 120000000, null),
(5, "DINGYO", "1990-11-05", "F", "CTO", 110000000, null),
(6, "JULIA", "2000-12-19", "M", "DEV_FRONT", 70000000, null),
...
SQL
복사
•
DEPARTMENT 테이블 데이터 추가
INSERT INTO DEPARTMENT VALUES
(1001, 'headquarter', 4),
(1002, 'HR', 6),
(1003, 'development', 1),
(1004, 'design', 3),
(1005, 'product', 13);
SQL
복사
•
PROJECT 테이블 데이터 추가
INSERT INTO PROJECT VALUES
(2001, '쿠폰 구매/선물 서비스 개발', 13, '2022-03-10', '2022-07-09'),
(2002, '확장성 있게 백엔드 리팩토링', 13, '2022-01-23', '2022-03-23'),
(2003, '홈페이지 UI 개선', 11, '2022-05-09', '2022-06-11');
SQL
복사
•
WORKS_ON 테이블 데이터 추가
INSERT INTO WORKS_ON VALUES
(5, 2001),
(13, 2001),
(1, 2001),
(8, 2001),
...
SQL
복사
3. 데이터 수정하기 (UPDATE)
3.1. 수정 명령 (UPDATE statement)
UPDATE table_name(s)
SET attribute = value [, attribute = value, .. ]
[ WHERE condition(s) ];
SQL
복사
3.2. 실습
•
Messi의 소속팀 정보를 업데이트
◦
employee ID가 1인 Messi는 개발(development)팀 소속이다.
◦
개발팀 ID는 1003이다.
UPDATE EMPLOYEE
SET dept_id = 1003
WHERE id = 1;
SQL
복사
•
개발팀 연봉을 두 배로 인상하고 싶다.
◦
개발팀 ID는 1003이다.
UPDATE EMPLOYEE
SET salary = salary * 2
WHERE dept_id = 1003;
SQL
복사
•
프로젝트 ID 2003에 참여한 임직원의 연봉을 두 배로 인상하고 싶다
UPDATE EMPLOYEE, WORKS_ON
SET salary = salary * 2
WHERE EMPLOYEE.id = WORKS_ON.empl_id AND WORKS_ON.proj_id = 2003;
SQL
복사
•
회사의 모든 구성원의 연봉을 두 배로 올리자!
UPDATE EMPLOYEE
SET salary = salary * 2
SQL
복사
4. 데이터 삭제하기 (DELETE)
4.1. 삭제 명령 (DELETE statement)
•
삭제할 레코드를 지정
DELETE FROM table_name
WHERE condition;
SQL
복사
•
테이블의 모든 레코드 삭제 (주의)
DELETE FROM table_name
SQL
복사
4.2. 실습
•
John이 퇴사를 하게 되면서 employee 테이블에서 John 정보를 삭제해야 한다.
◦
John의 employee ID는 8이다.
◦
현재 John은 project 2001에 참여하고 있었다.
DELETE FROM EMPLOYEE WHERE id = 8;
SQL
복사
•
Jane이 휴직을 떠나게 되면서 현재 진행 중인 프로젝트에서 중도하차하게 됐다.
◦
Jane의 ID는 2다.
DELETE FROM WORKS_ON WHERE empl_id = 2;
SQL
복사
•
현재 Dingyo가 두 개의 프로젝트에 참여하고 있었는데 프로젝트 2001에 선택과 집중을 하기로 하고 그 외의 프로젝트에서는 빠지기로 했다.
◦
Dingyo의 ID는 5다.
DELETE FROM WORKS_ON WHERE empl_id = 5 and proj_id != 2001;
SQL
복사
•
회사에 큰 문제가 생겨서 진행중인 모든 프로젝트들이 중단됐다.
DELETE FROM PROJECT;
SQL
복사