home강의 홈으로
Section 4. MySQL 더 깊이 알아가기
Lesson 2. 뷰 - 가상의 테이블
-- 뷰 생성
CREATE VIEW section_view AS
SELECT section_id, section_name
FROM sections;
-- 뷰 조회
SELECT * FROM section_view;
-- 뷰 삭제
DROP VIEW section_view;
뷰를 사용하는 이유
1. 보안 - 테이블 구조 및 내용 숨기기
CREATE VIEW menu_view AS
SELECT
menu_id,
menu_name,
CONCAT(
SUBSTRING(business_name, 1, 1),
REPEAT('*', CHAR_LENGTH(business_name) - 1)
) AS business,
price,
likes AS evaluation
FROM businesses B
INNER JOIN menus M
ON M.fk_business_id = B.business_id;
2. 편의 - 복잡한 쿼리 사전 구현
CREATE VIEW business_view AS
SELECT
section_name,
business_name,
(SELECT COUNT(*) FROM menus M
WHERE M.fk_business_id = B.business_id
) AS menu_count,
(SELECT AVG(likes) FROM menus M
WHERE M.fk_business_id = B.business_id
) AS menu_avg_likes,
(SELECT AVG(stars) FROM ratings R
WHERE R.fk_business_id = B.business_id
) AS avg_stars,
(SELECT comment FROM ratings R
WHERE R.fk_business_id = B.business_id
ORDER BY created DESC LIMIT 1
) AS recent_comment
FROM businesses B
INNER JOIN sections S
ON S.section_id = B.fk_section_id;
내용수정이 가능한 뷰
- 집계함수 사용하지 않음(MAX, MIN, AVG...)
- GROUP BY 사용하지 않음
- UNION, DISTINCT 사용하지 않음
- SELECT절에 서브쿼리 없음
- WHERE절의 서브쿼리가 FROM절의 테이블 참조하지 않음
- 조인은 INNER만 가능
-- 가능
UPDATE section_view
SET section_name = '서양식'
WHERE section_id = 5;
-- 가능
UPDATE menu_view
SET price = price + 1000
WHERE menu_name LIKE '%냉면';
-- 불가
UPDATE business_view
SET business_name = '화룡반점'
WHERE business_name = '화룡각';
🤔얄코에게 질문하기질문은 반.드.시 이리로 보내주세요! ( 강의사이트 질문기능 ✖ )
🛑질문 전 필독!!
- 구글링을 먼저 해 주세요. 들어오는 질문의 절반 이상은 구글에 검색해 보면 1분 이내로 답을 찾을 수 있는 내용들입니다.
- 오류 메시지가 있을 경우 이를 구글에 복붙해서 검색해보면 대부분 짧은 시간 내 해결방법을 찾을 수 있습니다.
- 강의 페이지에 추가사항 등 놓친 부분이 없는지 확인해주세요. 자주 들어오는 질문은 페이지에 추가사항으로 업데이트됩니다.
- "유료파트의 강의페이지는 어디 있나요?" - 각 영상의 시작부분 검은 화면마다 해당 챕터의 강의페이지 링크가 있습니다.
- 질문을 보내주실 때는 문제가 어떻게 발생했고 어떤 상황인지 등을 구체적으로 적어주세요. 스크린샷을 첨부해주시면 더욱 좋습니다.