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. 데이터 조회하기 (SELECT)
2.1. 조회 명령 (SELECT statement)
SELECT attribute(s)
FROM table(s)
[ WHERE condition(s) ];
SQL
복사
2.2. 실습
SELECT 기초
•
project 22를 리딩(leading)하고 있는 임직원의 ID와 이름과 직군을 알고 싶다.
SELECT EMPLOYEE.id, EMPLOYEE.name, position
FROM EMPLOYEE, PROJECT
WHERE PROJECT.id = 2002 and PROJECT.leader_id = EMPLOYEE.id;
SQL
복사
◦
PROJECT.id = 22 ⇒ selection condition
◦
PROJECT.leader_id = EMPLOYEE.id ⇒ join condition
◦
EMPLOYEE.id, EMPLOYEE.name, position ⇒ projection attributes
•
두 개 이상의 테이블이 조인되면, 동일한 이름의 열이 여러 테이블에 존재하거나 잠재잭으로 존재할 가능성이 있으므로 각 열 이름 앞에 테이블 이름을 명시적으로 지정하는 것을 권장한다.
SELECT EMPLOYEE.id, EMPLOYEE.name, position
FROM EMPLOYEE, PROJECT
WHERE PROJECT.id = 2002 and PROJECT.leader_id = id;
SQL
복사
AS 키워드 사용하기
•
AS는 테이블에 별칭(alias)을 붙일 때 사용한다.
SELECT E.id, E.name, position
FROM EMPLOYEE AS E, PROJECT AS P
WHERE P.id = 22 and P.leader_id = E.id;
SQL
복사
•
AS는 생략 가능하다.
SELECT E.id, E.name, position
FROM EMPLOYEE E, PROJECT P
WHERE P.id = 2002 and P.leader_id = E.id;
SQL
복사
•
AS는 attribute에도 별칭(alias)을 붙일 수 있다.
SELECT E.id AS leader_id, E.name AS leader_name, position
FROM EMPLOYEE E, PROJECT P
WHERE P.id = 2002 and P.leader_id = E.id;
SQL
복사
DISTINCT 키워드 사용하기
•
DISTINCT는 SELECT 결과에서 중복되는 tuples를 제외하고 싶을 때 사용한다.
•
디자이너들이 참여하고 있는 프로젝트들의 ID와 이름을 알고 싶다.
SELECT P.id, P.name
FROM EMPLOYEE AS E, WORKS_ON AS W, PROJECT AS P
WHERE E.position = 'DSGN' and
E.id = W.empl_id and W.proj_id = P.id;
SQL
복사
•
중복된 튜플 제거
SELECT DISTINCT P.id, P.name
FROM EMPLOYEE AS E, WORKS_ON AS W, PROJECT AS P
WHERE E.position = 'DSGN' and
E.id = W.empl_id and W.proj_id = P.id;
SQL
복사
LIKE 키워드 사용하기
기능 | 문자 | 설명 |
LIKE 연산자 | 문자열 패턴 매칭(pattern matching)에 사용되는 SQL 연산자 | |
예약 문자 | % | 0개 이상의 문자와 매칭 |
단일 문자 매칭 | - | 1개의 문자와 매칭 |
이스케이프 문자 | \ | 특수 문자를 escape시켜서 일반 문자로 취급 |
•
이름이 N으로 시작하거나 N으로 끝나는 임직원들의 이름을 알고 싶다.
SELECT name
FROM EMPLOYEE
WHERE name LIKE 'N%' OR name LIKE '%N';
SQL
복사
•
이름에 NG가 들어가는 임직원들의 이름을 알고 싶다.
SELECT name
FROM EMPLOYEE
WHERE name LIKE '%NG%';
SQL
복사
•
이름이 J로 시작하는, 총 네 글자의 이름을 가지는 임직원들의 이름을 알고 싶다.
SELECT name
FROM EMPLOYEE
WHERE name LIKE 'J____';
SQL
복사
•
%로 시작하거나 _로 끝나는 프로젝트 이름을 찾고 싶다면?
SELECT name
FROM PROJECT
WHERE name LIKE '\%%' OR name LIKE '%\_';
SQL
복사
* (asterisk) 사용하기
•
* (asterisk)는 선택된 tuples의 모든 attributes를 보여주고 싶을 때 사용한다.
•
ID가 9인 임직원의 모든 attributes를 알고 싶다.
SELECT *
FROM EMPLOYEE
WHERE id = 9;
SQL
복사
•
조인된 테이블에서 * (asterisk)로 전체 열 조회하기
◦
결과적으로 조인된 테이블에서 두 테이블의 열이 모두 반환된다.
▪
카티션 곱(Cartesian Product) 방식
SELECT *
FROM EMPLOYEE, PROJECT
WHERE PROJECT.id = 2002 and PROJECT.leader_id = EMPLOYEE.id;
SQL
복사
WHERE 절 없는 SELECT
•
테이블에 있는 모든 tuples를 반환한다.
•
모든 임직원의 이름과 생일을 알고 싶다.
SELECT name, birth_date
FROM EMPLOYEE;
SQL
복사
참고 자료
다음 글