[데이터조작어 - 검색(SELECT)]

 

이곳에 작성되는 예제와 내용은 학교 수업의 내용으로 구성된 내용입니다. 다소 내용이 부족하더라도 양해부탁드립니다.

 

* SELECT 기본 문법

 

SELECT [ALL | DISTINCT] 속성 이름(들)
FROM 테이블 이름(들)
[WHERE 검색조건(들]
[GROUP BY 속성이름]
[HAVING 검색조건(들)]
[ORDER BY 속성이름 [ASC | DESC]]

 

SQL문(질의문) 작성 시 처음 접하시는 분들은 위의 기본문법의 형태나 예제와 같이 SELECT, FROM 등의 절로 줄을 나누어 작성하시는 것을 추천합니다.

 

 

* 예제

 

1. 모든 도서의 이름과 가격을 검색하시오.

SELECT bookname, price
FROM Book;

 

2. 모든 도서의 도서번호, 도서이름, 출판사, 가격을 검색하시오.

SELECT bookid, bookname, publisher, price
FROM Book;

 

3. 도서 테이블에 있는 모든 출판사를 검색하시오.

SELECT pulbisher
FROM Book;

 

* WHERE 조건 연산자

술어 연산자
비교 =, < >, <, <=, >, >=
범위 BETWEEN
집합 IN, NOT IN
패턴 LIKE
NULL IS NULL, IS NOT NULL
복합조건 AND, OR, NOT

 

 

4. 가격이 20,000원 미만인 도서를 검색하시오.

SELECT *
FROM Book
WHERE price < 20000;

 

5. 출판사가 '굿스포츠' 혹은 '대한미디어' 인 도서를 검색하시오.

SELECT * 
FROM Book
WHERE publisher NOT IN ('굿스포츠', '대한미디어');

 

6. 가격이 10,000원 이상 20,000 이하인 도서를 검색하시오.

SELECT *
FROM Book
WHERE price >= 10000 AND 20000;
SELECT * 
FROM Book
WHERE price >= 10000 AND price <= 20000;

 

 

6번은 2개 질의문으로 둘다 가능합니다.

7. '축구의 역사'를 출간한 출판사를 검색하시오.

SELECT bookname, publisher
FROM Book
WHERE bookname LIKE '축구의 역사';

 

8. 도서 이름에 '축구'가 포함된 도서를 출간한 출판사를 검색하시오.

SELECT bookname, publisher
FROM Book
WHERE bookname LIKE '%축구%';

 

9. 도서 이름의 왼쪽 두 번째 위치에 '구'라는 문자를 갖는 도서를 검색하시오.

SELECT *
FROM Book
WHERE bookname LIKE '_구%';

 

* 와일드 문자의 종류

  - % : 0개 이상의 문자열과 일치

  - _ : 특정 위치의 1개의 문자와 일치

 

[SQL 기초]

 

* MySQL 접속 및 비밀번호 변경

 

  - 접속 및 사용법

  

    1. mysql -p Enter 후 Password 입력

 

    2. 데이터베이스 선택 : use DB명;

 

  - 패스워드 변경

 

    1. set password for ID@localhost = password('새암호');

 

  - LINUX 명령 실행 시

 

    1. system '명령어'

 

  - 종료 : \q

 

 

* SQL의 분류

 

  1. 데이터 정의어(DDL)

    

    - 테이블이나 관계의 구조를 생성 (CREATE, ALTER, DROP)

 

  2. 데이터 조작어(DML)

 

    - 테이블에 데이터를 검색, 삽입, 수정, 삭제 (SELECT, INSERT, DELETE, UPDATE)

 

  3. 데이터 제어어(DCL)

 

    - 데이터의 사용 권한을 관리하는 데 사용 (GRANT, REVOKE)

 

* 테이블 관련 명령어

 

  - 생성

  

 CREATE TABLE 테이블명 (
속성명 자료형,

 ...   );

  - 테이블 리스트 보기

    : show tables;

 

  - 테이블 구조 보기

    : desc 테이블명; (또는 explain 테이블명;)

[관계 대수]

 

* (셀렉션, Selection)

  - 릴레이션의 투플을 추출하기 위한 연산

  - 형식 :  (R은 릴레이션)

 

 

* 더블클릭을 하시면 수식을 수정할 수 있습니다.(프로젝션, Projection)

  - 릴레이션의 속성을 추출하기 위한 연산

  - 형식 : 더블클릭을 하시면 수식을 수정할 수 있습니다. (R은 릴레이션)

 

* 합집합

  - 두 개의 릴레이션을 합하여 하나의 릴레이션을 반환

  - 형식 :  (R, S는 릴레이션)

 

* 교집합

  - 두 릴레이션이 공통으로 가지고 있는 투플을 반환

  - 형식 :  (R, S는 릴레이션)

 

* 차집합

  - 첫번째 릴레이션에는 속하고 두번째 릴레이션에는 속하지 않는 투플을 반환

  - 형식 :  (R, S는 릴레이션)

 

* 카티전 프로덕트 

  - 두 릴레이션을 연결시켜 하나로 합칠 때 사용하며, 결과 릴레이션은 첫번째 릴레이션의 오른쪽에 두 번째 릴레이션의 모든 투플을 순서대로 배열하여 반환.

  - 결과 릴레이션의 차수 : 두 릴레이션 속성의 합

  - 결과 릴레이션의 카디날리티 : 두 릴레이션 투플의 곱

  - 형식 : (R, S는 릴레이션)

 

* 조인(Join)

  - 종류 : 기본연산(세타조인, 동등조인, 자연조인), 확장된 조인 연산(세미조인, 외부조인)

 

  1. 세타조인(Theta Join)

    - 조인에 참여하는 두 릴레이션의 속성 값을 비교하여 조건을 만족하는 투플만 반환

    - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

  2. 동등조인(Equi Join)

    - 세타조인에서 = 연산자를 사용한 조인을 말함. 보통 조인 연산이라고 하면 동등조인을 지칭함.

    - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

  3. 자연조인(Natural Join)

    - 동등조인에서 중복된 속성을 제거한 결과를 반환

    - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

  4. 외부조인

    - 자연조인 시 조인에 실패한 투플을 모두 보여주되 값이 없는 대응 속성에는 NULL 값을 채워서 반환함.

    - 종류 : 왼쪽 외부조인(Left outer join), 오른쪽 외부조인(Right outer join), 완전 외부조인(Full outer join)

 

    1) 왼쪽 외부조인(Left outer join)

       - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

    2) 오른쪽 외부조인(Right outer join)

       - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

    3) 완전 외부조인(Full outer join)

       - 형식 :  (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

  5. 세미조인

    - 자연조인을 한 후 두 릴레이션 중 한쪽 릴레이션의 결과만 반환함.

    - 닫힌 쪽의 릴레이션 투플만 반환함.

    - 형식 : 더블클릭을 하시면 수식을 수정할 수 있습니다., 더블클릭을 하시면 수식을 수정할 수 있습니다. (R, S는 릴레이션, r, s는 각각의 R, S의 속성)

 

* 디비전(Division)

  - 릴레이션의 속성 값의 집합으로 연산을 수행(연산은 차집합과 유사)

  - 형식 :  (R, S는 릴레이션)

 

 

[예제]

 

1. 마당 서점에서 판매하는 도서 중 8,000원 이하인 도서를 검색하시오.

 

     

 

2. 신간도서 안내를 위해 카달로그 발송 주소록을 만드시오.

   

 

3. 마당서점은 지점A와 지점B가 있다. 두 지점의 도서는 각 지점에서 관리하며 릴레이션 이름은 각각 도서A, 도서B이다. 마당 서점의 도서를 하나의 릴레이션으로 보이시오.

   

 

4. 마당 서점의 두 지점에서 동일하게 보유하고 있는 도서 목록을 보이시오.

   

 

5. 마당 서점의 두 지점에서 동일하게 보유하고 있는 도서 목록을 보이시오.

   

 

6. 도서 릴레이션과 고객 릴레이션의 카티전 프로덕트를 구하시오.

   

 

7. 고객과 고객의 주문사항을 모두 보이시오.

   

 

8. 마당 서점의 고객과 고객의 주문 내역을 보이시오.

   (단, 고객 기준으로 주문 내역이 없는 고객도 모두 보이시오.)

    고객(고객.고객번호,주문.고객번호)주문

 

9. 마당 서점의 고객과 고객의 주문 내역을 보이시오.

   (단, 주문 내역이 없는 고객과 고객 릴레이션에 고객번호가 없는 주문을 모두 보이시오.)

    고객(고객.고객번호,주문.고객번호)주문

 

10. 마당 서점의 고객과 고객의 주문 내역을 보이시오.

   (단, 주문 내역 기준으로 고객 릴레이션에 고객번호가 없는 주문도 모두 보이시오.)

    고객(고객.고객번호,주문.고객번호)주문

 

11. 마당 서점의 고객 중 주문 내역이 있는 고객의 고객 정보를 보이시오.

   

  

 

12. 마당 서점의 도서 중 가격이 8,000원 이하인 도서 이름과 출판사를 모두 보이시오.

   

 

13. 마당 서점의 박지성 고객의 거래 내역 중 주문 번호, 이름, 가격을 보이시오. (카티전프로덕트, 조인)

    - 카티전프로덕트 :

 

    - 조인 :

 

 

 

  

 

 

 

 

 

 

 

 

 

 

+ Recent posts