> 데이터 베이스 > MySQL 튜토리얼 > mysql 뷰의 용도는 무엇입니까?

mysql 뷰의 용도는 무엇입니까?

藏色散人
풀어 주다: 2020-09-19 13:57:08
원래의
22097명이 탐색했습니다.

mysql 보기의 기능: 1. 재사용성을 향상합니다. 2. 프로그램 실행에 영향을 주지 않고 데이터베이스를 재구성합니다. 3. 보안 성능을 향상하고 사용자마다 다른 보기를 설정할 수 있습니다. .

mysql 뷰의 용도는 무엇입니까?

테스트 테이블: 사용자의 ID, 이름, 나이, 성별 필드

테스트 테이블: 상품의 ID, 이름, 가격 필드

테스트 테이블: ug의 ID, 사용자 ID, 상품 ID 필드

의 역할 view 제가 경험한 이점은 다음과 같습니다.

기능 1:

기능과 마찬가지로 재사용성을 향상시킵니다. 이용자의 성명, 상품의 명칭을 수시로 파악하고 싶은 경우. 다음 SQL 언어를 사용해야 합니다. 예:

select a.name as username, b.name as goodsname from user as a, goods as b, ug as c where a.id=c.userid and c.goodsid=b.id;
로그인 후 복사

하지만 뷰에 따라 다르므로 다른 뷰를 만드세요. 예시

create view other as select a.name as username, b.name as goodsname from user as a, goods as b, ug as c where a.id=c.userid and c.goodsid=b.id;
로그인 후 복사

뷰를 생성하고 나면 이렇게 사용자 이름과 상품 이름을 알 수 있습니다. 예:

select * from other;
로그인 후 복사

위의 sql문으로 사용자 이름과 상품명을 알아낼 수 있습니다.

기능 2:

프로그램 실행에 영향을 주지 않고 데이터베이스를 재구성합니다. 특정 요구 사항으로 인해 사용자 테이블 usera와 userb 테이블을 분리해야 하는 경우 두 테이블의 구조는 다음과 같습니다.

테스트 테이블: usera에는 id, name, age 필드가 있습니다.

테스트 테이블: userb에는 id, name, sex 필드

PHP 측에서 sql 문을 사용하는 경우: select * from user; 이 문제를 해결하는 방법은 무엇입니까? 해결 방법: 보기를 만듭니다. 다음 SQL 문은 뷰를 생성합니다.

 create view user as select a.name,a.age,b.sex from usera as a, userb as b where a.name=b.name;
로그인 후 복사

위에서는 이름이 모두 고유하다고 가정합니다. 이때 PHP 측은 sql 문을 사용합니다. select * from user; 오류가 보고되지 않습니다. 이는 스크립트 프로그램을 변경하지 않고 데이터베이스 구조를 변경하는 기능을 실현합니다.

기능 3:

안전 성능이 향상되었습니다. 사용자마다 다른 보기를 설정할 수 있습니다. 예를 들어, 사용자는 사용자 테이블의 이름과 나이 데이터만 얻을 수 있고 성별 데이터는 얻을 수 없습니다. 이런 뷰를 만들 수 있습니다. 예는 다음과 같습니다.

create view other as select a.name, a.age from user as a;
로그인 후 복사

이 경우 sql 문을 사용하세요. select * from other; 대부분 이름과 나이 데이터만 가져올 수 있고 다른 데이터는 가져올 수 없습니다.

함수 4:

데이터를 더 명확하게 만듭니다. 원하는 데이터에 대해 원하는 종류의 뷰를 만드세요. 위의 세 가지 기능을 분석하면 이 기능을 쉽게 이해할 수 있을 것입니다

위 내용은 mysql 뷰의 용도는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿