mysql 보기의 기능: 1. 재사용성을 향상합니다. 2. 프로그램 실행에 영향을 주지 않고 데이터베이스를 재구성합니다. 3. 보안 성능을 향상하고 사용자마다 다른 보기를 설정할 수 있습니다. .
테스트 테이블: 사용자의 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!