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 = '화룡각';

🤔얄코에게 질문하기질문은 반.드.시 이리로 보내주세요! ( 강의사이트 질문기능 ✖ )

강의에서 이해가 안 되거나 실습상 문제가 있는 부분,
설명이 잘못되었거나 미흡한 부분을 메일로 알려주세요!

답변드린 뒤 필요할 경우 본 페이지에
관련 내용을 추가/수정하도록 하겠습니다.

이메일 주소
yalco@yalco.kr
메일 제목 (반드시 아래 제목을 붙여넣어주세요!)
[질문] 조금 더 깊은 MySQL 4-2

🛑질문 전 필독!!

  • 구글링을 먼저 해 주세요. 들어오는 질문의 절반 이상은 구글에 검색해 보면 1분 이내로 답을 찾을 수 있는 내용들입니다.
  • 오류 메시지가 있을 경우 이를 구글에 복붙해서 검색해보면 대부분 짧은 시간 내 해결방법을 찾을 수 있습니다.
  • 강의 페이지에 추가사항 등 놓친 부분이 없는지 확인해주세요. 자주 들어오는 질문은 페이지에 추가사항으로 업데이트됩니다.
  • "유료파트의 강의페이지는 어디 있나요?" - 각 영상의 시작부분 검은 화면마다 해당 챕터의 강의페이지 링크가 있습니다.
  • 질문을 보내주실 때는 문제가 어떻게 발생했고 어떤 상황인지 등을 구체적으로 적어주세요. 스크린샷을 첨부해주시면 더욱 좋습니다.
🌏 Why not change the world?